这个问题在这里已有答案:
我正在编写一个shell脚本,它读取csv文件并打印读取值:
#!/bin/bash
#echo"Starting execution in script"
exec < src/main/resources/test1.csv || exit 1
read header # read (and ignore) the first line
while IFS=, read name age salary ; do
echo "{"\"name"\":"\"${name}"\","\"age"\":${age},"\"salary"\":${salary}}"
done
test1.csv(输入文件):
name,age,salary
Subhash,26.0,10000.0
Amit,25.0,20000.0
Rohit,28.0,3000.0
Manoranjan,20.0,50000.0
在运行脚本时,我按以下方式获取输出:
}"name":"Subhash","age":26.0,"salary":10000.0
}"name":"Amit","age":25.0,"salary":20000.0
}"name":"Rohit","age":28.0,"salary":3000.0
}"name":"Manoranjan","age":20.0,"salary":50000.0
但是,如果我尝试在终端上运行上述脚本中的相同回声线,我将获得带有大括号的正确输出:
{"name": "subhash","age":23,"salary":1000}
上面的脚本有什么问题?
问题是你的test1.csv包含“windows”\r\n
行返回。
\r
被读作最后一个变量的一部分,然后在开口括号上打印下面的字符(}
) - echo正在完成它的工作。
我不确定为什么交互式地为你工作(你是否以相同的方式读取变量?)但是你只需要清理你的输入文件,或者从最后一个变量的末尾删除它,例如: ${salary%$'\r'}
(作为旁注,您不需要退出报价来打印转义报价,因此您的回显可能如下所示:
echo "{\"name\":\"${name}\",\"age\":${age},\"salary\":${salary%$'\r'}}"
)
我稍稍改编了你的剧本;删除了exec
和read header
。相反,我选择sed
来切断标题行和akw
来删除尾随空格(来自test1.csv文件)。这项工作对我很好:
while IFS=, read name age salary; do
echo "{"\"name"\":"\"${name}"\","\"age"\":${age},"\"salary"\":${salary}}"
done < <(sed 1d src/main/resources/test1.csv | awk '{$1=$1};1')