我正试图从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\'
最佳答案
在尝试使用不同的语法之后,我设法使其工作:
$entoli = 'zcat ' . str_replace(' ', '\ ', $filePath) . ' | sed \'/^,,,,/d\' > ' . str_replace(' ', '\ ', $temp);
exec($entoli);
它也适用于
awk
:$entoli = 'zcat ' . str_replace(' ', '\ ', $filePath) . ' | awk \'!/^,,,,/\' > ' . str_replace(' ', '\ ', $temp);