Sed - 从csv文件中删除空行

时间:2015-11-02 16:04:19

标签: php linux sed

我正在尝试从gz(压缩)文件中提取一些.csv文件。我想删除excel文件中空白的行。我使用下面的代码,但它不起作用:

$entoli = 'zcat ' . str_replace(' ', '\ ', $filePath) . ' | sed \'/^\s*$/d\'  > ' . str_replace(' ', '\ ', $savePath);
exec($entoli);

其中$filePath是原始压缩目录,$savePath是保存解压缩文件的目录。另外,我正在使用str_replace(' ', '\ ', ....),以防路径中有空格。

之前我使用过此代码,以便删除不以日期格式开头的行,并且它可以正常工作:

$entoli = 'zcat ' . str_replace(' ', '\ ', $filePath) . ' | sed \'/^[0-9][0-9][0-9][0-9]-[0-9][0-9]-[0-9][0-9]/!d\'  > ' . str_replace(' ', '\ ', $savePath);
exec($entoli);

所以,我认为只有这一行必须改变:

sed \'/^\s*$/d\'

1 个答案:

答案 0 :(得分:1)

尝试使用不同的语法后,我设法使其工作:

$entoli = 'zcat ' . str_replace(' ', '\ ', $filePath) . ' | sed \'/^,,,,/d\'  > ' . str_replace(' ', '\ ', $temp);
exec($entoli);

它也适用于awk

$entoli = 'zcat ' . str_replace(' ', '\ ', $filePath) . ' | awk \'!/^,,,,/\'  > ' . str_replace(' ', '\ ', $temp);