一部分以我想要查找的行号/usr/share/X11/xkb/symbols/us
开始xkb_symbols "dvorak" {
和结束。};
partial alphanumeric_keys
xkb_symbols "dvorak" {
name[Group1]= "English (Dvorak)";
key <TLDE> { [ grave, asciitilde, dead_grave, dead_tilde ] };
key <AE01> { [ 1, exclam ] };
key <AE02> { [ 2, at ] };
key <AE03> { [ 3, numbersign ] };
key <AE04> { [ 4, dollar ] };
key <AE05> { [ 5, percent ] };
key <AE06> { [ 6, asciicircum, dead_circumflex, dead_circumflex ] };
key <AE07> { [ 7, ampersand ] };
key <AE08> { [ 8, asterisk ] };
key <AE09> { [ 9, parenleft, dead_grave] };
key <AE10> { [ 0, parenright ] };
key <AE11> { [ bracketleft, braceleft ] };
key <AE12> { [ bracketright, braceright, dead_tilde] };
key <AD01> { [ apostrophe, quotedbl, dead_acute, dead_diaeresis ] };
key <AD02> { [ comma, less, dead_cedilla, dead_caron ] };
key <AD03> { [ period, greater, dead_abovedot, periodcentered ] };
key <AD04> { [ p, P ] };
key <AD05> { [ y, Y ] };
key <AD06> { [ f, F ] };
key <AD07> { [ g, G ] };
key <AD08> { [ c, C ] };
key <AD09> { [ r, R ] };
key <AD10> { [ l, L ] };
key <AD11> { [ slash, question ] };
key <AD12> { [ equal, plus ] };
key <AC01> { [ a, A, adiaeresis, Adiaeresis ] };
key <AC02> { [ o, O ] };
key <AC03> { [ e, E ] };
key <AC04> { [ u, U ] };
key <AC05> { [ i, I ] };
key <AC06> { [ d, D ] };
key <AC07> { [ h, H ] };
key <AC08> { [ t, T ] };
key <AC09> { [ n, N ] };
key <AC10> { [ s, S ] };
key <AC11> { [ minus, underscore ] };
key <AB01> { [ semicolon, colon, dead_ogonek, dead_doubleacute ] };
key <AB02> { [ q, Q ] };
key <AB03> { [ j, J ] };
key <AB04> { [ k, K ] };
key <AB05> { [ x, X ] };
key <AB06> { [ b, B ] };
key <AB07> { [ m, M ] };
key <AB08> { [ w, W ] };
key <AB09> { [ v, V ] };
key <AB10> { [ z, Z ] };
key <BKSL> { [ backslash, bar ] };
};
我可以找到返回 192 的环境的开始
grep -n 'xkb_symbols "dvorak"' /usr/share/X11/xkb/symbols/us | cut -d ":" -f1 > /tmp/lineNumberStartEnvironment
我做但输出空白
# http://unix.stackexchange.com/a/147664/16920
grep -zPo 'pin\(ABC\) (\{([^{}]++|(?1))*\})' /usr/share/X11/xkb/symbols/us
伪代码
- 首先转到 file 给出的行号
/tmp/lineNumberStartEnvironment
。 - 找到位于 行的内容的右括号
/tmp/lineNumberStartEnvironment
。- 对正文中的数据内容以及完整文件执行此操作
/usr/share/X11/xkb/symbols/us
- 对正文中的数据内容以及完整文件执行此操作
尝试heredoc直到下一行[cas,Kusalananda]
我做的事情我不知道我应该把什么放在定界符上;-n
也返回空白
sed -n -f - /usr/share/X11/xkb/symbols/us <<END_SED | cut -f1
/xkb_symbols "dvorak" {/,/^};/{
/xkb_symbols "dvorak" {/=
/^};/=
}
END_SED
但输出空白。
系统:Ubuntu 16.04
Grep:2.25
答案1
此脚本打印从行到下一行的范围内sed
匹配的行的行号(这将与我们获取的行号相同):/^};/
/xkb_symbols "dvorak" {/
/^};/
};
/xkb_symbols "dvorak" {/,/^};/{
/^};/=
}
如果您需要起始行号和结束行号:
/xkb_symbols "dvorak" {/,/^};/{
/xkb_symbols "dvorak" {/=
/^};/=
}
$ sed -n -f tiny_script.sed /usr/share/X11/xkb/symbols/us
192
248
或者:
$ sed -n -f - /usr/share/X11/xkb/symbols/us <<END_SED
/xkb_symbols "dvorak" {/,/^};/{
/xkb_symbols "dvorak" {/=
/^};/=
}
END_SED
编辑:要在变量中获取这两个数字,假设您使用的是 Bash:
pos=( $( sed -n -f - /usr/share/X11/xkb/symbols/us <<END_SED
/xkb_symbols "dvorak" {/,/^};/{
/xkb_symbols "dvorak" {/=
/^};/=
}
END_SED
) )
echo "start = " ${pos[0]}
echo "end = " ${pos[1]}
还有,嗨!又一位德沃夏克用户!
答案2
#! /usr/bin/awk -f
/"dvorak"/ {dvorak++};
/{/ && dvorak {b++} ;
/}/ && dvorak {b--} ;
dvorak && b == 0 && NR > 1 {
print NR;
exit
}
$ ./find-dvorak.awk /usr/share/X11/xkb/symbols/us
248
这使用了一个计数器 ( b
) ,每次看到左大括号时该计数器都会递增{
,每当看到右大括号时该计数器就会递减}
。它还使用标志变量 ( dvorak
) 来了解它是否在“dvorak”节内。
当 b == 0 且行号大于一时,打印行号。
错误:这不考虑注释掉的括号或嵌入字符串中的括号。
如果您想要左括号和右括号的行号:
#! /usr/bin/awk -f
/"dvorak"/ {dvorak++};
/{/ && dvorak {
b++;
if (!first++) {
print NR
}
} ;
/}/ && dvorak {b--} ;
dvorak && b == 0 && NR > 1 {
print NR;
exit
}
$ ./find-dvorak2.awk /usr/share/X11/xkb/symbols/us
192
248
这是一个允许您搜索任何xkb_symbols
节的版本:
#! /usr/bin/awk -f
match($0,"xkb_symbols.*\""search"\"") {found++};
/{/ && found {
b++;
if (!first++) {
print NR
}
} ;
/}/ && found {b--} ;
found && b == 0 && NR > 1 {
print NR;
exit
}
$ ./find-xkb_symbols.awk -v search=dvorak-intl /usr/share/X11/xkb/symbols/us
255
314