簡體   English   中英

Sed-從CSV文件中刪除空白行

[英]Sed - Delete blank rows from csv file

我正在嘗試從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);

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM