Vi替换命令用法练习

环境

 

RedHat Linux 9 + VWWare 8.0 + SSH 3.2.9

 

问题

 

假设有一个CSV(comma separated value)文件,里面有一些我们需要的信息,但是格式却有问题,目前数据的列顺序是:
姓名,公司名,州名缩写,邮政编码,现在我们希望讲这些数据重新组 织,以便在我们的某个软件中使用,
需要的格式为:姓名,州名缩写-邮政编码,公司名。
也就是说,我们要调整列顺序,还要合并两个列来构成一个新列。另外, 我们的软件不能接受逗号前后面有任何空格(包括空格和制表符)所

以我们还必须要去掉逗号前后的所有空格。


原文件是这样的:
Bill Jones,? ? ?HI-TEK Corporation ,? CA, 95011
Sharon Lee Smith,? Design Works Incorporated,? CA, 95012
B. Amos? ?,? Hill Street Cafe,? CA, 95013
Alexander Weatherworth,? The Crafts Store,? CA, 95014


我们希望把它变成这个样子:
Bill Jones,CA 95011,HI-TEK Corporation
Sharon Lee Smith,CA 95012,Design Works Incorporated
B. Amos,CA 95013,Hill Street Cafe
Alexander Weatherworth,CA 95014,The Crafts Store

 

 

解决

 

步骤一:将源文件保存成文本文档,如test.txt

 

步骤二:将test.txt上传到Linux中,这里可以使用SSH的文件上传功能。

 

 

步骤三:将test.txt用vi打开

 

 

步骤四:执行以下命令(输入命令时注意输入冒号,退出保存输入wq,退出不保存使用q或者q!):

 

1 去掉所有的问号(?)

 

%s/?//g


 

 

2 去掉逗号前后的所有空格

 

%s/[ \t]*,[ \t]*/,/g


 

 

3 实现功能

 

 

%s/\([^.]*\),\([^.]*\),\([^.]*\),\([^.]*\)/\1,\3 \4,\2/g


 

 

实现效果

 

 

评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值