如何解决Bash:在遍历二维属性文件时是否有条件子句
我有一个由 item [i] 定义的数据结构-包含-> subitem [k] 。我想写一个小的bash脚本来解析子项,然后项在命中特定子项时执行操作。
我的 sampletext.properties 文件是这样的:
Item1.subitem1=tom
Item1.subitem2=bob
Item2.subitem1=alice
Item2.subitem2=cindy
克服了Bash中二维数组的缺失,我编写了两个函数,一个函数用于获取键的值,另一个函数用于计算字符串的出现。
然后我建立一个for循环来解析项目,并尝试包括一个IF子句以敲击“ bob”并说出一些话。不幸的是,该脚本没有看到bob,并且似乎IF子句不起作用:
#!/bin/bash
# The input text file
PROPERTY_FILE=sampletext.properties
#Defining a function to get the value of a key
function getProperty {
PROP_KEY=$1
PROP_VALUE=`cat $PROPERTY_FILE | grep "$PROP_KEY" | cut -d'=' -f2 | tr -d '\n'`
echo $PROP_VALUE
}
# Counting the number of subitem1 entries
function countsubitem1 {
toolsnumber=`cat $PROPERTY_FILE | grep "Item[0-9].subitem1" | wc -l`
echo $toolsnumber
}
countsubitem1
for (( i=1; i<=$(countsubitem1); i++))
do
subitem1=`getProperty "Item$i.subitem1"`
subitem2=`getProperty "Item$i.subitem2"`
echo item$i:$(getProperty "Item$i.subitem1") # Testing the getProperty function again
echo subitem2:$subitem2 # Testing the for loop and the getProperty function
if [[ "$subitem2" == "bob" ]]; then
echo "I see bob!"
else
echo "No bob here!"
fi
done
启动脚本的内容:
2
item1:tom
subitem2:bob
No bob here!
item2:alice
subitem2:cindy
No bob here!
我期望的是
./samplebash.sh
2
item1:tom
subitem2:bob
I see bob!
item2:alice
subitem2:cindy
No bob here!
我尝试了几种中频条款的修改:
if [ "$subitem2" == "bob" ]; then
if [ '$subitem2' == 'bob' ]; then
但是我总是得到“这里没有鲍勃!”消息。
解决方法
请考虑以下代码:
readarray -t arr < "$PROPERTY_FILE"
getitem () {
for i in "${arr[@]}"; {
read item subitem value <<< ${i//[.=]/ }
case ${1:-1}${2:-2} in $item$subitem|${item}2|1$subitem)
echo "item=$item subitem=$subitem value=$value";;
esac
}
}
用法
$ getitem Item1
item=Item1 subitem=subitem1 value=tom
item=Item1 subitem=subitem2 value=bob
$ getitem Item1 subitem2
item=Item1 subitem=subitem2 value=bob
$ getitem '' subitem1
item=Item1 subitem=subitem1 value=tom
item=Item2 subitem=subitem1 value=alice
$ getitem Item2
item=Item2 subitem=subitem1 value=alice
,
使用关联数组
#!/bin/bash
# The input text file
PROPERTY_FILE=sampletext.properties
# Load the properties file
#
declare -A properties
loadProperties() {
local key value
if [[ "${#properties[@]}" -eq 0 ]]
then
# Lazy load the properties file
# Strip Windows-style CR as we go
#
while IFS='=' read -r key value
do
properties[$key]="$value"
done < <(tr -d '\r' <"$PROPERTY_FILE")
fi
}
# Get the value of a key
#
getProperty() {
local key="$1"
loadProperties
echo "${properties[$key]}"
}
# Count the number of "subitem1" items
#
countsubitem1() {
loadProperties
printf "%s\n" "${!properties[@]}" | awk -F. '$2 == "subitem1"' | wc -l
}
现在您可以使用这些函数并获取期望的值
countsubitem1
2
getProperty Item1.subitem2
bob
i=1
subitem1="$(getProperty "Item$i.subitem1")"
printf "%s\n" "$subitem1"
tom
请勿使用不推荐使用的function
关键字来声明函数。旨在使用小写的变量名称,以使您的名称不会与$PATH
之类的标准变量发生冲突。使用$( ... )
代替反引号将需要执行的值括起来。
感谢@William Pursell的提示!
添加| tr -d '\r'
会清除字符串并正确解析该字符串。
我现在获得:
item1subitem1:tom
subitem2:bob
I see bob!
item2subitem2:alice
subitem2:cindy
No bob here!
代码:
#!/bin/bash
# The input text file
PROPERTY_FILE=sampletext.properties
#Defining a function to get the value of a key
function getProperty {
PROP_KEY=$1
PROP_VALUE=`cat $PROPERTY_FILE | grep "$PROP_KEY" | cut -d'=' -f2 | tr -d '\n' | tr -d '\r'`
echo $PROP_VALUE
}
# Counting the number of subitem1 entries
function countsubitem1 {
toolsnumber=`cat $PROPERTY_FILE | grep "Item[0-9].subitem1" | wc -l`
echo $toolsnumber
}
for (( i=1; i<=$(countsubitem1); i++))
do
subitem1=`getProperty "Item$i.subitem1"`
subitem2=`getProperty "Item$i.subitem2"`
echo item"$i"subitem$i:$(getProperty "Item$i.subitem1") # Testing the getProperty function again
echo subitem2:$subitem2 # Testing the for loop and the getProperty function
if [[ "$subitem2" == "bob" ]]; then
echo "I see bob!"
else
echo "No bob here!"
fi
done
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。