0

所以基本上类似expr index '0123 some string' '012345789'但相反。
我想找到不是给定字符之一的第一个字符的索引...
如果可能的话,我宁愿不使用 RegEx...

4

4 回答 4

1

使用gnu awk并且FPAT你可以这样做:

str="0123 some string"

awk -v FPAT='[012345789]+' '{print length($1)}' <<< "$str"
4

awk -v FPAT='[02345789]+' '{print length($1)}' <<< "$str"
1

awk -v FPAT='[01345789]+' '{print length($1)}' <<< "$str"
2

awk -v FPAT='[0123 ]+' '{print length($1)}' <<< "$str"
5
于 2016-03-22T21:23:42.423 回答
1

您可以删除字符tr并从剩下的内容中选择第一个

left=$(tr -d "012345789" <<< "0123_some string"); echo ${left:0:1}
_

一旦你有 char 来查找索引,请遵循相同的

expr index "0123_some string" ${left:0:1}
5
于 2016-03-22T21:14:53.487 回答
0

我知道这是在 Perl 中,但我不得不说我喜欢它:

$ perl -pe '$i++while s/^\d//;$_=$i' <<< '0123 some string'
4

如果是基于 1 的索引,您可以使用$.在处理单行时初始化为 1 的索引:

$ perl -pe '$.++while s/^\d//;$_=$.' <<< '0123 some string'
5

我正在使用\d,因为我假设您错误地从列表中遗漏了数字 6012345789

索引当前指向的空间:

0123 some string
    ^ this space
于 2016-03-22T21:12:25.987 回答
0

即使 shell globing 看起来很相似,它也不是正则表达式。

它可以分两步完成:剪切字符串,计算字符(长度)。

#!/bin/dash
a="$1"                  ### string to process
b='0-9'                 ### range of characters not desired.
c=${a%%[!$b]*}          ### cut the string at the first (not) "$b".
echo "${#c}"            ### Print the value of the position index (from 0).

它是为在许多 shell 上工作而编写的(当然包括 bash)。

用于:

$ script.sh "0123_some string"
4
$ script.sh "012s3_some string"
3
于 2016-03-22T21:43:11.437 回答