亚洲av成人无遮挡网站在线观看,少妇性bbb搡bbb爽爽爽,亚洲av日韩精品久久久久久,兔费看少妇性l交大片免费,无码少妇一区二区三区

  免費注冊 查看新帖 |

Chinaunix

  平臺 論壇 博客 文庫
12
最近訪問板塊 發(fā)新帖
樓主: rm-rf
打印 上一主題 下一主題

[文本處理] 如何處理寬度固定的列 [復制鏈接]

論壇徽章:
20
卯兔
日期:2015-01-26 22:05:142015亞冠之薩濟拖拉機
日期:2015-09-10 15:15:282015亞冠之阿爾希拉爾
日期:2015-09-25 17:37:53程序設計版塊每日發(fā)帖之星
日期:2015-10-03 06:20:00程序設計版塊每日發(fā)帖之星
日期:2015-12-09 06:20:00CU十四周年紀念徽章
日期:2015-12-17 09:07:15程序設計版塊每日發(fā)帖之星
日期:2015-12-25 06:20:34程序設計版塊每日發(fā)帖之星
日期:2015-12-25 06:20:34程序設計版塊每日發(fā)帖之星
日期:2015-12-25 06:20:342015亞冠之廣州富力
日期:2015-08-27 19:29:56每日論壇發(fā)貼之星
日期:2015-08-26 06:20:002015亞冠之阿爾希拉爾
日期:2015-05-18 17:26:27
11 [報告]
發(fā)表于 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聯(lián)賽之八一
日期:2016-02-22 19:10:4215-16賽季CBA聯(lián)賽之深圳
日期:2016-12-01 10:34:0415-16賽季CBA聯(lián)賽之新疆
日期:2016-12-07 10:24:2915-16賽季CBA聯(lián)賽之同曦
日期:2016-12-15 12:06:43CU十四周年紀念徽章
日期:2016-12-18 13:03:4415-16賽季CBA聯(lián)賽之吉林
日期:2017-01-03 15:52:2515-16賽季CBA聯(lián)賽之遼寧
日期:2017-01-04 14:58:2415-16賽季CBA聯(lián)賽之遼寧
日期:2017-01-15 09:42:512016科比退役紀念章
日期:2017-02-06 17:21:50黑曼巴
日期:2017-02-10 15:46:1215-16賽季CBA聯(lián)賽之上海
日期:2017-03-18 10:14:5415-16賽季CBA聯(lián)賽之青島
日期:2017-03-18 22:00:44
12 [報告]
發(fā)表于 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 [報告]
發(fā)表于 2016-07-30 19:00 |只看該作者
moperyblue 發(fā)表于 2016-07-30 10:42
樓主  腳本里再加個判斷不就行了?


是的,我已經(jīng)在生產(chǎn)環(huán)境加上判斷了。
發(fā)這個帖子主要是我忘記了awk的FIELDWIDTHS,發(fā)完帖子后我又想起來了,腦筋不好
您需要登錄后才可以回帖 登錄 | 注冊

本版積分規(guī)則 發(fā)表回復

  

北京盛拓優(yōu)訊信息技術有限公司. 版權所有 京ICP備16024965號-6 北京市公安局海淀分局網(wǎng)監(jiān)中心備案編號:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年舉報專區(qū)
中國互聯(lián)網(wǎng)協(xié)會會員  聯(lián)系我們:huangweiwei@itpub.net
感謝所有關心和支持過ChinaUnix的朋友們 轉載本站內(nèi)容請注明原作者名及出處

清除 Cookies - ChinaUnix - Archiver - WAP - TOP