我想导入一个大的CSV文件,使用MySQL load data infile,文件用管道|分隔,用双引号""括起来。许多字段都是文本数据,双引号中包含双引号,而所有数据都在同一列中,因此仅当包含在引号中时,我才需要删除多余的双引号:
示例:
|"George Kastrioti "Skanderbeg""|""|""|"1926"|所需输出:
|"George Kastrioti Skanderbeg"|"|"|"1926"|尝试过sed,但没有真正的成功,有什么想法或建议吗?
发布于 2014-03-06 00:19:13
sed ': again
s/\(|"[^"|]*\)"\([^"|]*"\)/\1\2/g
t again
s/""/"/g' YourFile但我认为|""|比|"|更符合逻辑,所以这个版本应该更好(这只是一个想法,不知道你的真正需求和你的样本状态1只是空值的双引号)
sed ': again
s/\(|"[^"|]*\)"\([^"|]*"\)/\1\2/g
t again' YourFilehttps://stackoverflow.com/questions/22202190
复制相似问题