免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
123下一页
最近访问板块 发新帖
查看: 4507 | 回复: 25
打印 上一主题 下一主题

数据批量替换方法. [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2010-04-20 15:38 |只看该作者 |倒序浏览
数据如下:

FALKLAND ISLANDS (MALVINAS)           FK
FAROE ISLANDS         FO
FIJI         FJ
FINLAND         FI
FRANCE         FR
FRENCH GUIANA         GF
FRENCH POLYNESIA         PF
FRENCH SOUTHERN TERRITORIES         TF

请问如何将以上的数据修改为:

将每一行的最后两个字符放到每一行的最前面并组成如下格式数据:

'FK'=>'FALKLAND ISLANDS (MALVINAS)',
'FO'=>'FAROE ISLANDS',        
'FJ'=>'FIJI',        
'FI'=>'FINLAND',        
'FR'=>'FRANCE',        
'GF'=>'FRENCH GUIANA',        
'PF'=>'FRENCH POLYNESIA',        
'TF'=>'FRENCH SOUTHERN TERRITORIES',



在线等待各位的方法.

论坛徽章:
0
2 [报告]
发表于 2010-04-20 15:47 |只看该作者
回复 1# lasereyes
  1. sed -r "s/(.*).{10}(.{2})$/'\2'=>'\1',/" file
复制代码

论坛徽章:
0
3 [报告]
发表于 2010-04-20 15:48 |只看该作者
  1. awk -v v="'" '{l=substr($0,length($0)-1);NF-=1;print v""l""v"=>"v""$0""v","}' file
复制代码

论坛徽章:
0
4 [报告]
发表于 2010-04-20 15:49 |只看该作者
本帖最后由 where27 于 2010-04-20 15:56 编辑

回复 1# lasereyes
  1. sed -r "s/(.*[^ ]) +([^ ]+)$/'\2'==>'\1',/" file
复制代码
用这个吧,上面的那个不严谨

论坛徽章:
0
5 [报告]
发表于 2010-04-20 15:52 |只看该作者
本帖最后由 lkk2003rty 于 2010-04-20 15:58 编辑
  1. awk '{a="'\''"$NF"'\''=>'\''";for(i=NF-1;i>0;i--)$(i+1)=$i;$1=a;$NF=$NF"'\'',";}1' file | sed "s/' /'/g"
复制代码

论坛徽章:
0
6 [报告]
发表于 2010-04-20 15:53 |只看该作者
最后一个字段超过两个字符呢?
楼主你是要最后一个字段加到前面吧
  1. awk -v v="'" '{l=$NF;NF-=1;print v""l""v"=>"v""$0""v","}' file
复制代码

论坛徽章:
0
7 [报告]
发表于 2010-04-20 15:54 |只看该作者
本帖最后由 where27 于 2010-04-20 15:57 编辑

回复 6# ywlscpl


    。。。我是说我的不严谨呵呵,你写的比我好,再改
  1. sed -r "s/(.*[^ ]) +([^ ]+)$/'\2'==>'\1',/" file
复制代码

论坛徽章:
0
8 [报告]
发表于 2010-04-20 15:57 |只看该作者
回复 2# where27


    这个10需要观察啊。。。。老表兄果然厉害。。。

论坛徽章:
0
9 [报告]
发表于 2010-04-20 15:59 |只看该作者
回复 7# where27


嗯,我是在问楼主
不过可能楼主的数据最后一个字段定长为2个字符

论坛徽章:
0
10 [报告]
发表于 2010-04-20 16:00 |只看该作者
回复 8# lkk2003rty


    恩,已经改了
过奖过奖,我是菜鸟
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP