bash – 为什么正则表达式中少一个空间使我的sed变得奇怪?
发布时间:2020-12-15 21:02:11 所属栏目:安全 来源:网络整理
导读:这是我想弄清楚的一些正则表达式的例子.目标是剥离多余的空间,并通过sed使它在单词之间只有一个空格.给出的样本在sdf和sdk之间有三个空格: test@ubuntu:~/addr_book_script$echo "est sdf sdk" | sed 's/ */ /g'est sdf sdktest@ubuntu:~/addr_book_script$
这是我想弄清楚的一些正则表达式的例子.目标是剥离多余的空间,并通过sed使它在单词之间只有一个空格.给出的样本在sdf和sdk之间有三个空格:
test@ubuntu:~/addr_book_script$echo "est sdf sdk" | sed 's/ */ /g' est sdf sdk test@ubuntu:~/addr_book_script$echo "est sdf sdk" | sed 's/ */ /g' e s t s d f s d k 您会注意到两个sed语句仅在*之前的空格数上有所不同.第一个语句有两个空格,它的表现正是我想要的. 第二个语句在*之前有一个空格,它在每个字母和单词之间插入一个空格. 我知道*意味着任何数量的事件 – 它是我正在寻找的.我不明白的是为什么一个空间sed替换它的行为方式. 谢谢 解决方法sed 's/ */ /g' 正则表达式*匹配0次或更多次出现(空格). >在字符串的开头,找到0空格匹配并替换为单个空格 等等. 另一个例子: ~ >>> echo "est sdf sdk" | sed 's/a*/ /g' e s t s d f s d k 由于0字符匹配而发生替换. (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |