Cut在bash中是明智的

时间:2014-04-14 17:38:45

标签: bash awk cut

我正在尝试提取信息并将其从包含这些行的文本文件发送到数据库

EndDate=2014-04-08;Time=00:00:49;ID=1144877;AppName=Ad (ba);MetricName=EndUser1;average_network_time=0
EndDate=2014-05-08;Time=00:00:50;ID=1144878;AppName=Ad (qa);MetricName=EndUser/Apdex;score=1.0;s=0;t=0;f=0

我写的脚本是:

var1="EndUser"
var2="EndUser/Apdex"
var6="path to file"

for line in $var6
do

EndDate=`cut -d';' -f1 $line | cut -d'=' -f2`
echo $EndDate
Time=`cut -d';' -f2 $line | cut -d'=' -f2`
echo $Time
ID=`cut -d';' -f3 $line | cut -d'=' -f2`
echo $ID
AppName=`cut -d';' -f4 $line | cut -d'=' -f2`
echo $AppName
MetricName=`cut -d';' -f5 $line | cut -d'=' -f2`
echo $MetricName

if [ "$MetricName" == "$var1" ];then
echo "in If" 
average_network_time=`cut -d';' -f6 $line | cut -d'=' -f2`
echo "avg=$average_network_time"
echo "('$EndDate','$Time','$ID','$AppName','$MetricName','$average_network_time');"
mysql -h servername -u ID -p'pass' name -e "insert into check_copy(EndDate,Time,ID,AppName,MetricName,average_network_time) values ('$EndDate','$Time','$ID','$AppName','$MetricName','$average_network_time');"
fi

if [ "$MetricName" == "$var2" ];then
echo "in If2" 
score=`cut -d';' -f6 $line | cut -d'=' -f2`
echo $score
s=`cut -d';' -f7 $line | cut -d'=' -f2`
t=`cut -d';' -f8 $line | cut -d'=' -f2`
f=`cut -d';' -f9 $line | cut -d'=' -f2`
mysql -h servername -u ID -p'pass' name -e "insert into check_copy(EndDate,Time,ID,AppName,MetricName,score,s,t,f) values ('$EndDate','$Time','$ID','$AppName','$MetricName','$score','$s','$t','$f');"
fi

我得到的输出是:

2014-04-08 2014-05-08
00:00:49 00:00:50
1144877 1144878
Ad (ba) Ad (qa)
EndUser1 EndUser/Apdex

预期的产量:

2014-04-08 00:00:49 1144877 Ad (ba) EndUser1 0
2014-05-08 00:00:50 1144878 Ad (qa) EndUser/Apdex 1.0 0 0 0

我的问题:它本身并没有进入循环。可能是因为它是按列方式进行的 我希望它为各自的度量标准名称打印avg netwrok时间值,得分,s,t,f。

1 个答案:

答案 0 :(得分:1)

如果file

EndDate=2014-04-08;Time=00:00:49;ID=1144877;AppName=Ad (ba);MetricName=EndUser;average_network_time=0
EndDate=2014-05-08;Time=00:00:50;ID=1144878;AppName=Ad (qa);MetricName=EndUser/Apdex;score=1.0;s=0;t=0;f=0

以下sed命令

sed -n -r -e '/MetricName=EndUser;/{s/^EndDate=(.*);Time=(.*);ID=(.*);AppName=(.*);MetricName=(EndUser);average_network_time=(.*)$/\1 \2 \3 \4 \5 \6/gp}'  -e '/MetricName=EndUser\/Apdex/{s/^EndDate=(.*);Time=(.*);ID=(.*);AppName=(.*);MetricName=(EndUser\/Apdex);score=(.*);s=(.*);t=(.*);f=(.*)$/\1 \2 \3 \4 \5 \6 \7 \8 \9/gp}' file

将给出

2014-04-08 00:00:49 1144877 Ad (ba) EndUser 0
2014-05-08 00:00:50 1144878 Ad (qa) EndUser/Apdex 1.0 0 0 0

适用于GNU sed version 4.2.1。您可以通过修改mysql

中的replacement部分来直接生成s/pattern/replacement/pg查询