首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >删除双引号中的双引号

删除双引号中的双引号
EN

Stack Overflow用户
提问于 2014-03-05 23:36:15
回答 1查看 657关注 0票数 1

我想导入一个大的CSV文件,使用MySQL load data infile,文件用管道|分隔,用双引号""括起来。许多字段都是文本数据,双引号中包含双引号,而所有数据都在同一列中,因此仅当包含在引号中时,我才需要删除多余的双引号:

示例:

代码语言:javascript
复制
|"George Kastrioti "Skanderbeg""|""|""|"1926"|

所需输出:

代码语言:javascript
复制
|"George Kastrioti Skanderbeg"|"|"|"1926"|

尝试过sed,但没有真正的成功,有什么想法或建议吗?

EN

回答 1

Stack Overflow用户

发布于 2014-03-06 00:19:13

代码语言:javascript
复制
sed ': again
s/\(|"[^"|]*\)"\([^"|]*"\)/\1\2/g
t again
s/""/"/g' YourFile

但我认为|""||"|更符合逻辑,所以这个版本应该更好(这只是一个想法,不知道你的真正需求和你的样本状态1只是空值的双引号)

代码语言:javascript
复制
sed ': again
s/\(|"[^"|]*\)"\([^"|]*"\)/\1\2/g
t again' YourFile
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/22202190

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档