免费注册 查看新帖 |

Chinaunix

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

修改固定列的数据 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2008-11-07 17:35 |只看该作者 |倒序浏览
文件格式大致如下:
000001|ZINC|0301001|0|200808|JMJC001|20080911111111|abcdef|12345678900|1|9|
000002|ZINC|0301000|0|200808|JMJC001|20080911111111|abcdef|12345678900|1|9|
000003|ZINC|0301000|0|200808|JMJC001|20080911111111|abcdef|12345678900|1|9|
000001|ZINC|0301006|0|200808|JMJC001|20080911111111|abcdef|12345678900|1|9|
000001|ZINC|0301000|0|200808|JMJC001|20080911111111|abcdef|12345678900|1|9|
000005|ZINC|0301000|0|200808|JMJC001|20080911111111|abcdef|12345678900|1|9|
000001|ZINC|0301009|0|200808|JMJC001|20080911111111|abcdef|12345678900|1|9|
000001|ZINC|0301000|0|200808|JMJC001|20080911111111|abcdef|12345678900|1|9|
000001|ZINC|0301000|0|200808|JMJC001|20080911111111|abcdef|12345678900|1|9|
000007|ZINC|0301000|0|200808|JMJC001|20080911111111|abcdef|12345678900|1|9|
000001|ZINC|0301000|0|200808|JMJC001|20080911111111|abcdef|12345678900|1|9|
000001|ZINC|0301010|0|200808|JMJC001|20080911111111|abcdef|12345678900|1|9|
000001|ZINC|0301000|0|200808|JMJC001|20080911111111|abcdef|12345678900|1|9|
000008|ZINC|0301000|0|200808|JMJC001|20080911111111|abcdef|12345678900|1|9|
000001|ZINC|0301000|0|200808|JMJC001|20080911111111|abcdef|12345678900|1|9|
000001|ZINC|0301000|0|200808|JMJC001|20080911111111|abcdef|12345678900|1|9|
000009|ZINC|0301000|0|200808|JMJC001|20080911111111|abcdef|12345678900|1|9|

现在想把第3列的内容都换掉,该如何做?我做了个如下,哪位能帮忙改个简单点的.
#!/bin/usr/perl -w


use strict;

$^I = ".bak";
while(<>)
{
    my @line = split /\|/, $_;
    $line[2] = "030100048";
    $_ = join "|" @line;

    print ;
}

论坛徽章:
0
2 [报告]
发表于 2008-11-07 18:15 |只看该作者
已经很简单了。。。

论坛徽章:
3
戌狗
日期:2014-09-10 17:07:162015年辞旧岁徽章
日期:2015-03-03 16:54:15wusuopu
日期:2016-06-17 17:43:45
3 [报告]
发表于 2008-11-07 18:21 |只看该作者

  1. #!/usr/bin/perl -w

  2. use strict;

  3. $^I = ".bak";
  4. my $txt = '030100048';
  5. while (<>) {
  6.     s/^(\w+\|\w+\|)(\w+)/$1$txt/;
  7.     print;
  8. }
复制代码

[ 本帖最后由 ynchnluiti 于 2008-11-7 18:38 编辑 ]

论坛徽章:
1
2015年辞旧岁徽章
日期:2015-03-03 16:54:15
4 [报告]
发表于 2008-11-07 18:27 |只看该作者
perl -i.bak -ple 'substr($_,12,7)="030100048"' urfile

论坛徽章:
23
15-16赛季CBA联赛之吉林
日期:2017-12-21 16:39:27白羊座
日期:2014-10-27 11:14:37申猴
日期:2014-10-23 08:36:23金牛座
日期:2014-09-30 08:26:49午马
日期:2014-09-29 09:40:16射手座
日期:2014-11-25 08:56:112015年辞旧岁徽章
日期:2015-03-03 16:54:152015年迎新春徽章
日期:2015-03-04 09:49:0315-16赛季CBA联赛之山东
日期:2017-12-21 16:39:1915-16赛季CBA联赛之广东
日期:2016-01-19 13:33:372015亚冠之山东鲁能
日期:2015-10-13 09:39:062015亚冠之西悉尼流浪者
日期:2015-09-21 08:27:57
5 [报告]
发表于 2008-11-07 18:34 |只看该作者
perl -i.bak -pe 's/((?:.*?\|){2})(?:.*?\|)/${1}030100048|/' urfile

论坛徽章:
0
6 [报告]
发表于 2008-11-07 18:39 |只看该作者
刚开始看perl语言入门第四版第9章了. 先来消化下各位的代码,谢谢楼上的各位!

论坛徽章:
0
7 [报告]
发表于 2008-11-07 18:43 |只看该作者
想问下flw, 前面两列的长度可能不一定相同,第3列也有可能不是每行固定的长度. 这个就用不了了吧.

论坛徽章:
3
戌狗
日期:2014-09-10 17:07:162015年辞旧岁徽章
日期:2015-03-03 16:54:15wusuopu
日期:2016-06-17 17:43:45
8 [报告]
发表于 2008-11-07 18:45 |只看该作者

回复 #7 hr_it 的帖子

方法很多,根据情况灵活运用

论坛徽章:
0
9 [报告]
发表于 2008-11-07 18:50 |只看该作者
原帖由 ynchnluiti 于 2008-11-7 18:45 发表
方法很多,根据情况灵活运用


恩, 你的那个现在看懂了,5楼的那个还没怎么看懂.

论坛徽章:
0
10 [报告]
发表于 2008-11-07 21:41 |只看该作者
perl -i.bak -F'/\|/' -lane '$,="|";print @F[0..1],"030100048",@F[3..$#F]'  urfile

其实跟楼主的原理一样
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP