免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
楼主: wzy
打印 上一主题 下一主题

请求帮助编辑一个文本处理的shell  关闭 [复制链接]

论坛徽章:
0
11 [报告]
发表于 2004-03-11 22:48 |只看该作者

请求帮助编辑一个文本处理的shell

这里有一文件:ww.txt
其中内容如下:
   wang|03/07/2004|104950|100|
    zhang|03/07/2004|123224|200|
    he|02/01/2004|85012|350|
           ......
在该例子中,如果第三列格式为HH:MM:SS或者H:MM:SS(只有小时小于10时才是,如8:50:12,不会有12:7:31类的格式。当出现85012格式时,首先在其前面加“0”,改为085012形式,然后再处理为如下形式,各位老大,如何办呢?
wang|2004-03-07 10:49:50|100
zhang|2004-03-07 12:32:24|200
he|2004-02-01 08:50:12|350
......

论坛徽章:
0
12 [报告]
发表于 2004-03-12 00:23 |只看该作者

请求帮助编辑一个文本处理的shell

原帖由 "wzy" 发表:
这里有一文件:ww.txt
其中内容如下:
   wang|03/07/2004|104950|100|
    zhang|03/07/2004|123224|200|
    he|02/01/2004|85012|350|
           ......
在该例子中,如果第三列格式为HH:MM:SS或者H:MM..........
都到这个地步了,您自己难道就不...

论坛徽章:
1
荣誉版主
日期:2011-11-23 16:44:17
13 [报告]
发表于 2004-03-12 04:07 |只看该作者

请求帮助编辑一个文本处理的shell

bjgirl, what is gsub?

论坛徽章:
1
荣誉版主
日期:2011-11-23 16:44:17
14 [报告]
发表于 2004-03-12 04:11 |只看该作者

请求帮助编辑一个文本处理的shell

OK..OK.. I know it is global substituting....

论坛徽章:
0
15 [报告]
发表于 2004-03-12 17:38 |只看该作者

请求帮助编辑一个文本处理的shell

惭愧,得开始好好学习awk了

论坛徽章:
0
16 [报告]
发表于 2004-03-13 10:10 |只看该作者

请求帮助编辑一个文本处理的shell

#!/usr/bin/awk -f
BEGIN{ FS="|" }
{split($2,date,"/"
n=1
if(length($3)<6){
$3="0"$3
}
for ( i = 1 ;i<=5;i++2 ){
time[n]=substr($3,i,2)
n++
}
print $1"|"date[3]"-"date[2]"-"date[1]" "time[3]":"time[2]":"time[1]"|"$4
}
我也写了一个。就是第三列有问题。帮忙看看

论坛徽章:
0
17 [报告]
发表于 2004-03-13 13:21 |只看该作者

请求帮助编辑一个文本处理的shell

我也是这样想的,假如第3域是5位就在前面补0

论坛徽章:
0
18 [报告]
发表于 2004-03-13 14:13 |只看该作者

请求帮助编辑一个文本处理的shell

原文件:
wang|03/07/2004|104950|100|
zhang|03/07/2004|123224|200|
he|02/01/2004|85012|350|
  1. cat filename|awk 'BEGIN{FS="|";OFS="|"}{gsub(/\//,"-")}\
  2. {if(length($3)!=6){$3="0"$3}{gsub(/04\|/,"04 ")}print}'|\
  3. sed 's/\([0-9][0-9]\)\([0-9][0-9]\)\([0-9][0-9]\)/\1:\2:\3/g'
复制代码
测试结果:
wang|03-07-2004 10:49:50|100|
zhang|03-07-2004 12:32:24|200|
he|02-01-2004 08:50:12|350|

论坛徽章:
0
19 [报告]
发表于 2004-03-13 14:16 |只看该作者

请求帮助编辑一个文本处理的shell

注解:
{if(length($3)!=6){$3="0"$3} ###补0
s/\([0-9][0-9]\)\([0-9][0-9]\)\([0-9][0-9]\)/\1:\2:\3/g###冒号
望前辈指教

论坛徽章:
0
20 [报告]
发表于 2004-03-14 00:20 |只看该作者

请求帮助编辑一个文本处理的shell

第一步:pro1.sh
#!/usr/bin/awk -f
BEGIN{ FS="|" }
{if(length($3)!=6){
$3="0"$3
}
print $1"|"$2"|"$3"|"$4
}
第二步:pro2.sh
./pro1.sh ww.txt >tmp.txt
awk -F"|" '{print $1"|"substr($2,7,4)"-"substr($2,1,2)"-"substr($2,4,2)" "substr($3,1,2)":"substr($3,3,2)":"substr($3,5,2)"|"$4}' tmp.txt >jg.txt
rm tmp.txt
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP