0

我尝试删除前几天不匹配的 csv 文件的所有日期。但我发现不是正确的解决方案。

date,price
2018-07-02,162.17
2018-06-29,161.94
2018-06-28,162.22
2018-06-27,162.32
2018-06-12,163.01
2018-06-11,163.53
2018-05-31,164.87
2018-05-30,165.59
2018-05-29,165.42
2018-05-25,165.96
2018-05-02,164.94
2018-04-30,166.16
2018-04-27,166.69

我想要的输出变成

date,price
2018-06-29,161.94
2018-05-31,164.87
2018-04-30,166.16

我用 cut + grep 试试

cut -d, -f1 file.csv | grep -E "28|29|30"

组合 -f1,2 时工作但什么也不带。

我发现 csvkit 在我看来是正确的工具,但我发现不是多个 grep 的解决方案。

csvgrep -c 1 -m 30 file.csv

给我带来正确的结果,但如何组合多个搜索选项?我尝试 -m 28,29,30 和 -m 28 -m 29 -m 30 都不起作用。最好在每个月的最后一天工作。

也许有人在这里有一个想法。

谢谢你和美好的星期天西尔维奥

4

1 回答 1

2

您想获取该月最后一天的所有记录。但是月份的长度会有所不同(28-29-30-31)。

我不明白您为什么cut要提取第一个字段(日期部分),因为第二个字段中的数据看起来根本不像日期(xx-xx)。

我建议grep直接使用来显示符合以下模式的行mm-dd;其中mm是月份编号,dd是月份的最后一天。

这个命令应该可以解决问题:

grep -E "01-31|02-(28|29)|03-31|04-30|05-31|06-30|07-31|08-30|09-31|10-30|11-31|12-30" file.csv

该命令将给出以下输出:

2018-05-31,164.87
2018-04-30,166.16
于 2018-07-08T11:43:23.770 回答