4

我正在使用 bash 脚本(Ubuntu 12.10)处理来自文本文件的一些数据。

基本思想是我使用 grep 从文件中选择某一行。接下来,我使用 sed 处理该行以获取数字。grep 和 sed 命令都在工作。我可以回显这个数字。

但是结果与字符串的连接出错了。

当我从变量或文件执行 grep 命令时,组合字符串时会得到不同的结果。当我 grep 文件时,连接出错。当我使用与文件中相同的文本 grep 变量时,它按预期工作。

我对文件中的 grep 做错了什么?

test.pdb 的内容

REMARK overall = 324.88  
REMARK bon     = 24.1918  
REMARK coup    = 0  

我的剧本

#!/bin/bash

#Correct function
echo "Working code"
TEXT="REMARK overall = 324.88\nREMARK bon     = 24.1918\nREMARK coup    = 0\n"
DATA=$(echo -e $TEXT | grep 'overall' | sed -n -e "s/^.*= //p" )

echo "Data: $DATA"
DATA="$DATA;0"
echo $DATA


#Not working
echo ""
echo "Not working code"
DATA=$(grep 'overall' test.pdb | sed -n -e "s/^.*= //p")

echo "Data: $DATA"
DATA="$DATA;0"
echo $DATA

输出

Working code
Data: 324.88
324.88;0

Not working code
Data: 324.88
;04.88
4

3 回答 3

2

我对同样的问题发疯了。

真正的问题是您的“test.pdb”可能有错误的 EOL(行尾)字符。

Linux EOL:LF(又名 \n)

Windows EOL:CR LF(又名 \r \n)

这意味着 echo 和 grep 会对这个额外的字符 (\r) 产生问题,幸运的是 tr、sed 和 awk 可以正确管理它。

所以你也可以尝试:

DATA=$(grep 'overall' test.pdb | sed -n -e "s/^.*= //p" | sed -e 2s/\r$//")

或者

DATA=$(grep 'overall' test.pdb | sed -n -e "s/^.*= //p" | tr -d '\r')

于 2015-03-26T12:46:02.410 回答
0

试试这个:

SUFFIX=";0"
DATA="${DATA}${SUFFIX}"
于 2013-03-17T15:43:05.263 回答
0

使用,我猜它会更可靠和更干净:

$ awk '$2=="overall"{print "Working code\nData: " $4 "\n" $4 ";0"}' file.txt
Working code
Data: 324.88
324.88;0
于 2013-03-17T15:48:31.233 回答