免费注册 查看新帖 |

Chinaunix

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

[文本处理] 如何处理宽度固定的列 [复制链接]

论坛徽章:
20
卯兔
日期:2015-01-26 22:05:142015亚冠之萨济拖拉机
日期:2015-09-10 15:15:282015亚冠之阿尔希拉尔
日期:2015-09-25 17:37:53程序设计版块每日发帖之星
日期:2015-10-03 06:20:00程序设计版块每日发帖之星
日期:2015-12-09 06:20:00CU十四周年纪念徽章
日期:2015-12-17 09:07:15程序设计版块每日发帖之星
日期:2015-12-25 06:20:34程序设计版块每日发帖之星
日期:2015-12-25 06:20:34程序设计版块每日发帖之星
日期:2015-12-25 06:20:342015亚冠之广州富力
日期:2015-08-27 19:29:56每日论坛发贴之星
日期:2015-08-26 06:20:002015亚冠之阿尔希拉尔
日期:2015-05-18 17:26:27
11 [报告]
发表于 2016-07-30 00:05 |只看该作者
本帖最后由 songyc_2015 于 2016-07-30 00:06 编辑

回复 1# rm-rf
  1. cfg:
  2. 第1列: char 8
  3. 第2列: char 6
  4. 第3列: char 4
  5. 第4列: number 8
  6. 第5列: char 6

  7. file:
  8. 12345678 123456 1234 12345678 123456
  9. abcd     abc3        7834     4556  
  10. 34       45     dfd  444            

  11. $ awk 'FNR==NR{a[NR]=$NF;b[NR]=$(NF-1);l=NR;next}{for(i=1;i<=l;i++){c=i==1?1:c;x=substr($0,c,a[i]);gsub(" ","",x);y=x==""?"null":x;d=y=="null"?"":b[i]~/char/?"\x27":"";s=s?s","d y d:d y d;c=c+a[i]+1}printf("insert into t values(%s);\n",s);s=x=y=c=z}' cfg file
  12. insert into t values('12345678','123456','1234',12345678,'123456');
  13. insert into t values('abcd','abc3',null,7834,'4556');
  14. insert into t values('34','45','dfd',444,null);
复制代码

论坛徽章:
28
15-16赛季CBA联赛之八一
日期:2016-02-22 19:10:4215-16赛季CBA联赛之深圳
日期:2016-12-01 10:34:0415-16赛季CBA联赛之新疆
日期:2016-12-07 10:24:2915-16赛季CBA联赛之同曦
日期:2016-12-15 12:06:43CU十四周年纪念徽章
日期:2016-12-18 13:03:4415-16赛季CBA联赛之吉林
日期:2017-01-03 15:52:2515-16赛季CBA联赛之辽宁
日期:2017-01-04 14:58:2415-16赛季CBA联赛之辽宁
日期:2017-01-15 09:42:512016科比退役纪念章
日期:2017-02-06 17:21:50黑曼巴
日期:2017-02-10 15:46:1215-16赛季CBA联赛之上海
日期:2017-03-18 10:14:5415-16赛季CBA联赛之青岛
日期:2017-03-18 22:00:44
12 [报告]
发表于 2016-07-30 10:42 |只看该作者
本帖最后由 moperyblue 于 2016-07-30 10:45 编辑

楼主  脚本里再加个判断不就行了?
  1. BEGIN{
  2.   FIELDWIDTHS="9 7 5 9 7"
  3. }
  4. {
  5.   for (i=1;i<=NF;i++){
  6.     gsub(/\s*$/,null,$i)
  7.     $i=$i==null?"null":i!=4?"'"$i"'":$i
  8.   }
  9.   printf("insert into t values(%s,%s,%s,%s,%s);\n",$1,$2,$3,$4,$5)
  10. }
复制代码

论坛徽章:
2
技术图书徽章
日期:2013-12-17 13:52:152015亚冠之萨济拖拉机
日期:2015-07-19 11:07:52
13 [报告]
发表于 2016-07-30 19:00 |只看该作者
moperyblue 发表于 2016-07-30 10:42
楼主  脚本里再加个判断不就行了?


是的,我已经在生产环境加上判断了。
发这个帖子主要是我忘记了awk的FIELDWIDTHS,发完帖子后我又想起来了,脑筋不好
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP