雨过天晴12 2018-11-16 11:29 采纳率: 0%
浏览 710
已采纳

请教一个shell的写法对于列数不固定的文件把每列的值取出来,如然后写入insert SQL

1.想把文件中的每列值取出来,然后作为insert 语句中的值,写成insert SQL。
2.同时文件中的列数是不固定的,可能先需要对列数进行一个判定。_
文件样本:
955,2018,10,1, ,FMSCCCM ,2018-10-19 15:04:55.511
602,2018,10,1,602,44638994,2018-10-22 02:49:28.944
608,2018,10,1,608,44638994,2018-10-22 02:49:28.946
610,2018,10,1,610,44638994,2018-10-22 02:49:28.948
612,2018,10,1,612,44638994,2018-10-22 02:49:28.95
613,2018,10,1, ,FMSCCCM ,2018-10-19 15:06:15.403
615,2018,10,1,615,44638994,2018-10-22 02:49:28.952
616,2018,10,1,616,44638994,2018-10-22 02:49:28.953
618,2018,10,1,618,44638994,2018-10-22 02:49:28.955
619,2018,10,1, ,FMSCCCM ,2018-10-19 15:07:19.518

期望结果是生成insert SQL:
insert into tablename values ('955','2018','10','1',' ','FMSCCCM' ,'2018-10-19 15:04:55.511');
insert into tablename values ('602','2018','10','1','602 ','44638994' ,'2018-10-22 02:49:28.944');
insert into tablename values ('608','2018','10','1','608 ','44638994' ,'2018-10-22 02:49:28.946');
insert into tablename values ('610','2018','10','1','610 ','44638994' ,'2018-10-22 02:49:28.948);
目前能写出来把文件每一列值取出,作为insert语句中的值
如:
while read line
do
echo $line > tmp
col1=awk -F "," '{print $1}' tmp
col2=awk -F "," '{print $2}' tmp
col3=awk -F "," '{print $3}' tmp
col4=awk -F "," '{print $4}' tmp
col5=awk -F "," '{print $5}' tmp
col6=awk -F "," '{print $6}' tmp
col7=awk -F "," '{print $7}' tmp

echo "insert into tablename values ('$col1','$col2','$col3','$col4','$col5','$col6','$col7');"

done < test4.log

但是由于文件中的**列数不固定**,脚本目前是写死了7列,不知道列数不一样的话,如何先对列进行一个判定,然后再根据实际列数进行取值!
求指教!

  • 写回答

3条回答 默认 最新

  • 雨过天晴12 2019-01-02 11:33
    关注

    while read line
    do
    echo $line | sed "s/^/insert into ${SCHEMA_NM.TABLE_NM} values (\'/g; s/$/\');/g; s/,/\',\'/g"

    done < ${SCHEMA_NM.TABLE_NM}.csv

    我用这个办法解决了insert 语句问题

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(2条)

报告相同问题?

悬赏问题

  • ¥15 水下机器人的半物理仿真研究
  • ¥15 微服务假死,一段时间后自动恢复,如何排查处理
  • ¥50 webrtc-streamer TCP rtsp
  • ¥15 cplex运行后参数报错是为什么
  • ¥15 之前不小心删了pycharm的文件,后面重新安装之后软件打不开了
  • ¥15 vue3获取动态宽度,刷新后动态宽度值为0
  • ¥15 升腾威讯云桌面V2.0.0摄像头问题
  • ¥15 关于Python的会计设计
  • ¥15 聚类分析 设计k-均值算法分类器,对一组二维模式向量进行分类。
  • ¥15 stm32c8t6工程,使用hal库