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  {z\2}  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 退格

\B 反斜线,与\ 相同

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

\e 转义字符

\f 换页

\n 换行

\r 回车

\t 制表符

分支和量词

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

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

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

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

{num} 0-255 之间的整数

逆向引用

([ab])\1       #匹配aa bb

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

(?:expression)

TCL Strings的更多相关文章

  1. Tcl之group arguments

    1 doubel quotes This allows substitutions to occur within the quotations - or "interpolation&qu ...

  2. Tcl之Math

    expr is for Tcl to do math operations. It takes all of its arguments ("2 + 2" for example) ...

  3. Hacker Rank: Two Strings - thinking in C# 15+ ways

    March 18, 2016 Problem statement: https://www.hackerrank.com/challenges/two-strings/submissions/code ...

  4. Tcl internal variables

    Tcl internal variables eryar@163.com 在Tcl中内置了一些变量,并赋予了一定的功能.内置变量列表如下: 变量名称 功能描述 argc 指命令行参数的个数. argv ...

  5. StackOverFlow排错翻译 - Python字符串替换: How do I replace everything between two strings without replacing the strings?

    StackOverFlow排错翻译 - Python字符串替换: How do I replace everything between two strings without replacing t ...

  6. Multiply Strings

    Given two numbers represented as strings, return multiplication of the numbers as a string. Note: Th ...

  7. [LeetCode] Add Strings 字符串相加

    Given two non-negative numbers num1 and num2 represented as string, return the sum of num1 and num2. ...

  8. [LeetCode] Encode and Decode Strings 加码解码字符串

    Design an algorithm to encode a list of strings to a string. The encoded string is then sent over th ...

  9. [LeetCode] Group Shifted Strings 群组偏移字符串

    Given a string, we can "shift" each of its letter to its successive letter, for example: & ...

随机推荐

  1. JS变量和数据类型及其转化

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

  2. centos软连接的增删

    软连接操作 增加 ln-s 源文件 软连接名 修改 ln –snf 源文件 软连接 删除 只删除软连接 rm -rf 软连接名 只删除源文件 rm -rf 源文件 -r循环 -f强制

  3. 巨杉Tech | SparkSQL+SequoiaDB 性能调优策略

    当今时代,企业数据越发膨胀.数据是企业的价值,但数据处理也是一种技术挑战.在海量数据处理的场景,即使单机计算能力再强,也无法满足日益增长的数据处理需求.所以,分布式才是解决该类问题的根本解决方案.而在 ...

  4. optim.SDG 或者其他、实现随机梯度下降法

    optim.SDG 或者其他.实现随机梯度下降法 待办 实现随机梯度下降算法的参数优化方式 另外还有class torch.optim.ASGD(params, lr=0.01, lambd=0.00 ...

  5. ubuntu apt

    一些命令: sudo apt-get update  更新源 sudo apt-get install package --reinstall  重新安装包 sudo apt-get upgrade ...

  6. 【Python requests多页面爬取案例】

    "```python import requests from fake_useragent import UserAgent # 随机ua库 class Boring(): def __i ...

  7. SSM开发基于Java EE在线图书销售系统

           SSM(Spring+Spring MVC+MyBatis)开发基于Java EE在线图书销售系统  网站成功建立和运行很大部分取决于网站开发前的规划,因此为了在网站建立过程中避免一些不 ...

  8. javascript 循环读取数组中的值

    //数组 var a = ["#F85C6F", "#78B0F0", "#DB83ED", "#8EC656", &q ...

  9. 安全相关的Linux知识

    本文用于记录在安全中的Linux常用命令,基础命令可以移步去菜鸟教程(https://www.runoob.com/linux/linux-tutorial.html)学习 Linux重要的4个热键 ...

  10. dp--C - Mysterious Present

    C - Mysterious Present Peter decided to wish happy birthday to his friend from Australia and send hi ...