linux - 删除行中两个符号之间的字符串

标签 linux sed awk command

我正在尝试从 csv 文件中删除一行中两个符号之间的字符串。这是我的示例文件:

1.1.1.1,A-B:,awef.C.D.E
1.1.1.2,A-B:,few.C.D.E
1.1.1.3,A-B:,dfs.C.D
1.1.1.4,A-B:,few.C.D
1.1.1.5,A-B:,fdsferger.C.D.E
1.1.1.6,A-B:,wef.C.D
1.1.1.7,A-B:,jty.C.D.E

输出是这样的:

1.1.1.1,A-B:,C.D.E
1.1.1.2,A-B:,C.D.E
1.1.1.3,A-B:,C.D
1.1.1.4,A-B:,C.D
1.1.1.5,A-B:,C.D.E
1.1.1.6,A-B:,C.D
1.1.1.7,A-B:,C.D.E

有什么办法可以实现吗?

最佳答案

下面的 awk 命令可以做到这一点:

awk 'BEGIN{FS=OFS=","}{sub("[^.]*.","",$3);print}'

它基本上将每一行分成三个逗号分隔的字段,然后删除第三个字段的初始部分,直到并包括第一个 . 字符。

然后它再次输出它们。

请参阅以下演示文稿:

pax> echo '1.1.1.1,A-B:,awef.C.D.E
1.1.1.2,A-B:,few.C.D.E
1.1.1.3,A-B:,dfs.C.D
1.1.1.4,A-B:,few.C.D
1.1.1.5,A-B:,fdsferger.C.D.E
1.1.1.6,A-B:,wef.C.D
1.1.1.7,A-B:,jty.C.D.E' | awk 'BEGIN{FS=OFS=","}{sub("[^.]*.","",$3);print}'

1.1.1.1,A-B:,C.D.E
1.1.1.2,A-B:,C.D.E
1.1.1.3,A-B:,C.D
1.1.1.4,A-B:,C.D
1.1.1.5,A-B:,C.D.E
1.1.1.6,A-B:,C.D
1.1.1.7,A-B:,C.D.E

关于linux - 删除行中两个符号之间的字符串,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/22188327/

相关文章:

linux - 使用 awk 打印由 "-"分隔的变量

awk + ​​将值导出到 awk

PHP 通知 : A non well formed numeric value encountered in/var/www/zephyr/library/XenForo/Application. php on line 1534

linux - 升级到 Ubuntu 15.04 后 MongoDB 服务不工作

python - 如何使用python挂载网络目录?

Vim /塞德 : Delete Only Single Blank Lines

Linux - 在每个文件中查找并替换为不同的字符串

unix - awk/sed : replace all fields if any field matches a pattern

java - UTF-8 的不可打印字符 - SUSE Linux Java 不支持

linux - Bash - 从一种模式替换为另一种模式以及介于两者之间的所有内容