我正在尝试提取信息并将其从包含这些行的文本文件发送到数据库
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。
答案 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
查询