TCL Strings

append    Append values to variable

binary      Insert and extract fields from binary strings

regexp      Regular expression pattern matching

ex1:

regexp {^[0-9]+$}   510

->1

regexp {^[0-9]+$}  -510

-> 0

regexp  {^([0-9]+) *([a-z]+)} "Walk 10 km”  a b c

# a = 10km ; b = 10 ; c =km

-indices  返回索引值,a 为5 9 ,b 为5 6  ,c 为 7 9 

-inline    返回数据列表   {10 km}  10 km

-line       激活分换行的匹配  $除普通功能外,与新行前的空字符串匹配。^除了它的普通功能外,与新行后的空字符串匹配

regsub      Regular expression string substution

 regsub there "they live there lives"   their x

->1    #返回1 匹配成功,x = they live their lives

regsub  thrre "they live there lives" their x

->0 #返回0 匹配不成功 ,x= they live there lives.无论是否发生替换,都会设置x 变量

-all 一直查找替换,否则只替换1次。返回替换次数

regsub zz abbab  a  x  # x=zzbbab

regsub -all zz abbab a x  # x=zzbbzzb  返回值为2

-nocase 不区分大小写

-start  从指定字符处开始查找。命令指定字符中一个字符索引

-line 启动区分换行匹配

--明确的表示命令选项结束

regsub  -all --  a|b  axaab  &&  x  #x=aaxaaaabb   &表示被替换的子字符串

regsub -all  -- (a+)(ba*)  aabaabxab  {z2}  x     #  x=zbaabxzb 后面有一个b,前面没有1个b的序列替换为z

format      printf() -style string formatting

ex1:

    set msg  [format  "%s is %d years old]

    set msg  "$name is $age years old"

ex2:

 puts [format "%4d %12.3f"  $i  [expr exp($i)]]

scan          sscanf() -style string formatting

 ex1:

scan "16 units,24.2% margin"  "%d units, %f margin"  a b      #a的值为16,b的值为24.2

->2           #完成两次转换

ex2:

proc next c {

scna $c %c   i  # ASCII 转为整数

format %c [expr {$i + 1}]   #整数加一转为 ASCII

}

next a

-> b

string compare   Lexical(词汇的) string comparison

string first     Search for first occurrence of substring

string index     Return character from string

string last        Search for last occurance of substring

string length    Return number of characters in string

string range     Return range of characters in string

string tolower   Covert to lowercase

string toupper   Covert to uppercase

string trim          Remove leading and trailing characters

string trimleft      Remove leading characters

string trimright   Remove trailing characters

string wordend   Return end position of word in string

string wordstart  Return start position of word in string

subst                  Blackslash,command,variable substitutions

string map  dictionary string  # string中出现dictionary关键字置换为相应的值  -nocase  不区分大小写

string  is  digital  1234  #数据类型判断,ascii/boolean/double/float/integer/list/lower/alpha

->1

Tcl 有两种匹配模式:

1.简单的通配符样式,源于unix外壳中的文件名展开机制

*   0个或多个任意字符组成的字符匹配

? 一个任意字符匹配

[chars]   chars中任意一个字符匹配

x   于单字符x匹配,用于特殊字符,如* ? [ ]

2.正则表达式模式匹配


.  匹配任意的单个字符

^ 指定与输入字符串的开头匹配

$指定与输入字符串的结尾匹配

m 指定单词的开头进行匹配

M 指定单词的结尾进行匹配

k 匹配非字母也非数字的字符k(.匹配字面上的句点符号)

[chars]  与chars 中的字母匹配

(regexp) 匹配正则表达式 regexp 用于分组或识别匹配的子字符串

*  与0或多个前述的原子组成的序列匹配

+ 与1个或多个前述的原子组成的序列匹配

?与空字符串匹配,或与前述的一个原子匹配

{m}   与前述原子正好匹配m次的序列

{m,}  与前述原子至少匹配m次的序列

{m,n}  至少匹配m次,最多n次

re1 | re2  任意一个指定正则表达式的匹配

转义序列

a   铃声

 退格

B 反斜线,与 相同

cX  取得给定字符X的低5位,然后以这5位为低5位,其他补0做转义后的字符

e 转义字符

f 换页

换行

回车

制表符

分支和量词

* + ? 被称为量词,可以跟在原子后面,用来指定它的重复次数。

* 0或多个该原子组成的匹配序列

+ 1个或多个该原子组成的匹配序列

? 空字符串或与这个字符串匹配字符串匹配

{num} 0-255 之间的整数

逆向引用

([ab])1       #匹配aa bb

非捕获子表达式:处理速度快,不能逆向引用非捕获子表达式。

(?:expression)

原文地址:https://www.cnblogs.com/lelin/p/11281540.html