人家用的是shell,结果一楼给个java代码,问答区真的演。
判断文件名中是否包含子串,其实很简单,就是长字符串是否包含短字符串,我这边给个例子:
1、使用[[ ... ]]
str="我是长字符串"
subStr="我是短字符串"
if [[ ${str} == *${subStr}* ]] ;then
echo -e "字符串 '${str}' 包含: '${subStr}'."
else
echo -e "字符串 '${str}' 不包含: '${subStr}'."
fi
2、使用grep
str="我是长字符串"
subStr="我是短字符串"
if echo ${str} | grep ${subStr} ;then
echo -e "字符串 '${str}' 包含: '${subStr}'."
else
echo -e "字符串 '${str}' 不包含: '${subStr}'."
fi
3、使用=~
str="我是长字符串"
subStr="我是短字符串"
if [[ ${str} =~ ${subStr} ]] ;then
echo -e "字符串 '${str}' 包含: '${subStr}'."
else
echo -e "字符串 '${str}' 不包含: '${subStr}'."
fi
可以使用Java语言中的String类的contains方法。我写个代码给你
public static void main(String[] args) throws Exception {
StreamExecutionEnvironment env = StreamExecutionEnvironment.getExecutionEnvironment();
DataStream<String> text = env.readTextFile("file:///path/to/file");
text.filter(new FilterFunction<String>() {
@Override
public boolean filter(String value) throws Exception {
return value.contains("substring");
}
}).print();
env.execute("Flink Streaming Java API Skeleton");
}
但是得确保文件的路径是正确的,如果仍然进不去,请检查控制台输出的日志信息,以确定问题的根本原因。
版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。
实时计算Flink版是阿里云提供的全托管Serverless Flink云服务,基于 Apache Flink 构建的企业级、高性能实时大数据处理系统。提供全托管版 Flink 集群和引擎,提高作业开发运维效率。