我有一个目录,其中包含具有唯一时间的 txt 文件,这些文件是在一夜之间生成的。鉴于文件中的唯一时间戳,我试图列出这些文件。 文件名的一些示例如下:
file_20210122_1130_1.txt
file_20210122_1133_1.txt
file_20210122_1221_1.txt
file_20210122_1342_1.txt
file_20210122_1721_1.txt
file_20210122_1911_1.txt
file_20210122_2009_1.txt
file_20210122_2020_1.txt
file_20210122_2130_1.txt
...
我希望能够列出 1900 年到 2100 年之间的文件(使用文件名本身中包含的模式),它应该列出以下内容:
file_20210122_1911_1.txt
file_20210122_2009_1.txt
file_20210122_2020_1.txt
我正在尝试使用下面的代码片段,但它部分有效并且没有列出所有文件。
cd /home/somedir/files;
ls *.txt | awk '/1900/,/2100/'
如有任何帮助,我们将不胜感激。
最佳答案
如果文件名的格式相同,你可以使用awk并将字段分隔符设置为_
然后检查第三个字段是否在1900和2100之间
ls -A1 *.txt | awk -v FS=_ '$3 >= 1900 && $3 <= 2100'
输出
file_20210122_1911_1.txt
file_20210122_2009_1.txt
file_20210122_2020_1.txt
关于具有特定名称范围的 Bash 列表文件,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/67942752/