作者热门文章
- android - RelativeLayout 背景可绘制重叠内容
- android - 如何链接 cpufeatures lib 以获取 native android 库?
- java - OnItemClickListener 不起作用,但 OnLongItemClickListener 在自定义 ListView 中起作用
- java - Android 文件转字符串
我需要遍历 Hadoop 文件系统中的所有 csv 文件。我可以用
列出 HDFS 目录中的所有文件> hadoop fs -ls /path/to/directory
Found 2 items
drwxr-xr-x - hadoop hadoop 2 2016-10-12 16:20 /path/to/directory/tmp
-rwxr-xr-x 3 hadoop hadoop 4691945927 2016-10-12 19:37 /path/to/directory/myfile.csv
并且可以使用
遍历标准目录中的所有文件for filename in /path/to/another/directory/*.csv; do echo $filename; done
但是我怎样才能将两者结合起来呢?我试过了
for filename in `hadoop fs -ls /path/to/directory | grep csv`; do echo $filename; done
但这给了我一些废话,比如
Found
2
items
drwxr-xr-x
hadoop
hadoop
2
2016-10-12
....
最佳答案
这应该可行
for filename in `hadoop fs -ls /path/to/directory | awk '{print $NF}' | grep .csv$ | tr '\n' ' '`
do echo $filename; done
关于bash - 循环遍历 HDFS 目录中的文件,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/40010820/
我是一名优秀的程序员,十分优秀!