建立在在this thread的答案,你可以这样做:
#! /bin/bash
if [ -f "${HOME}/.${0##*/}" ]; then
config="${HOME}/.${0##*/}rc"
else
config="/etc/${0##*/}"
fi
if [ -f "$config" ]; then
section=global
while read -r line; do
if [[ $line =~ ^(#|$) ]]; then continue; fi
if [[ $line =~ ^\[[[:alpha:]_][[:alnum:]_]*\]$ ]]; then
section=${line#[}
section=${section%]}
elif [[ $line =~ ^[[:alpha:]_][[:alnum:]_]*= ]]; then
eval "${section}_${line%%=*}"=\${line#*=}
fi
done <"$config"
fi
这假设bash
,并解析配置文件是这样的:
# comment
global1=gval1
global2=gval2
[section1]
variable_1=value_11
variable_2=value_12
[section2]
variable_1=value_21
variable_2=value_22
它设置在配置文件中指定的变量,通过该部分的名称为前缀的名字。评论和空白行被忽略。
概念证明:
set | egrep '^(global|section)[^=]' | \
while read -r line; do
key=${line%%=*}
eval "val=\${$key}"
printf '%s = [%s]\n' "$key" "$val"
done
输出:
global_global1 = [gval1]
global_global2 = [gval2]
section1_variable_1 = [value_11]
section1_variable_2 = [value_12]
section2_variable_1 = [value_21]
section2_variable_2 = [value_22]
这个问题是相似的:http://stackoverflow.com/questions/3410306/bash-read-in-config-file-带同一变量的多个实例?rq = 1只需要在看到区域标题时开始处理行,并在到达下一个标题时停止。 – Barmar
@randy,你的分组中有重复的键。这是打算或仅仅是一个例子。前者可以group1和group2有单独的变量? –
如果你可以控制配置文件格式,而不是处理一个你必须解析的文件,那么使用'source'格式编写配置要容易得多。引入**关联数组**可以带来更大的灵活性。例如。 ('declare -A group1; group1 =([var1] =“test 1”[var2] =“test 2”...)')。然后,而不是解析它,只是'。/path/to/my/config“,然后简单地使用'$ {group1 [var2]}'等等。 –