我有一个格式如下的文件:
123 2 3 48 85.64 85.95
Park ParkName Location
12 2.2 3.2 48 5.4 8.9
现在我想写一个shell脚本来从这个文件中提取行。 每行的第一项是一种标志。对于不同的旗帜,我会做出不同的过程。 请参阅下面的代码:
head= ` echo "$line" | grep -P "^\d+" `
if [ "$head" != "" ]; then
(do something...)
fi
head=` echo "$line" | grep -P "^[A-Z]+" `
if [ "$head" != "" ]; then
(do something...)
fi
代码有效。但我不喜欢复杂的写作方式2"如果"。 我想要一些简单的东西:
if [ "$head" != "" ]; then
(do something...)
elif [ "$head" != "" ]; then
(do something...)
fi
有什么想法吗?
答案 0 :(得分:1)
纯粹的bash解决方案怎么样? Bash具有内置的正则表达式功能,您可以使用~
字符触发。
请注意,使用bash读取行处理大型文件不会产生最佳性能。
#!/bin/bash
file=$1
while read line
do
echo "read [$line]"
if [[ $line =~ ^[0-9] ]]; then
echo ' Processing numeric line'
elif [[ $line =~ ^[A-Za-z] ]]; then
echo ' Processing a text line'
fi
done < $file
答案 1 :(得分:0)
这个怎么样?我想它会满足你的要求
文件强>
123 2 3 48 85.64 85.95
Park ParkName位置
12 2.2 3.2 48 5.4 8.9
<强> script.sh 强>
while read line
do
echo $line | grep -qP "^\d+" && echo "Line starts with Numbers"
echo $line | grep -qP "^[a-zA-Z]+" && echo "Line Starts with String"
done < file
<强>输出: - 强>
bash script.sh
行以数字
开头Line以字符串开头
行以数字
开头