首先贴一下常见的命令
命令 | 说明 |
---|---|
list arg1 arg2 … | 创建一个列表 |
lindex list index | 返回列表 list 中的第 index 个元素(element)值 |
llength list | 计算列表 list 元素个数 |
lrange list index1 index2 | 返回指定范围内(从 index1 到 index2)的元素 |
lappend list arg1 arg2 … | 将新元素追加到原来列表 list 后组成新的列表 |
linsert list index arg1 arg2 … | 将新元素插入到 list 中位于 index 元素之前的位置上 |
lreplace list index1 index2 arg1 arg2 … | 替换指定范围的元素 |
lsearch ?mode? list value | 根据匹配模式 mode,查找 list 中与 value 匹配的元素位置索引。mode 一般为-exact、-glob 和regexp.默认为-glob。找不到返回-1。 |
lsort ?switches? list | 根据 开关选项对列表进行排序 |
concat list1 list2 … | 连接多个列表内容成一个列表 |
join list joinChars | 以 joinChars 为分隔符将列表中的元素合并在一起 |
split string splitChars | 以 splitChars 中的字符作为分隔符将字符串分解为列表元素。 |
foreach var list {proc body} | 遍历列表各项,逐次将各元素值存入 var 中并执行 proc body。相当于一个循环控制语句。 |
1.list 命令
list 命令用来创建列表。一个列表可以包含子列表,即列表可以嵌套。
set l1 [list Sun Mon Tues]
结果=>Sun Mon Tues
set l2 [list $l1 Wed] ;#列表 l1 含有三个元素
结果=> {Sun Mon Tues} Wed
set str1 “Sun Mon Tues”
结果=>Sun Mon Tues
set l2 [list $str1 Wed] ;#列表 l2 中含有两个元素。第一个元素用花括号括起来。
结果=>{Sun Mon Tues} Wed ;#和上面的命令结果相同:“列表是特殊的字符串”。
2.concat 命令
concat 命令以空格为分隔符将多个列表拼装在一起形成新的列表。它和双引号的作用比较相似。
set x {1 2}
结果=> 1 2
set y "KaTeX parse error: Expected 'EOF', got '#' at position 9: x 3 " ; #?x 被替换后,作为列表结构的花括号被去掉,
结果=> 1 2 3 ; #元素被提出来和 3 一起作为新列表的元素
set y “$x {3}”
结果=> 1 2 {3}
set y [concat $x 3] ;#结果同上面的双引号
结果=> 1 2 3
set y [concat $x {3}]
结果=> 1 2 3
3.lindex 命令
lindex 命令返回列表中指定位置的特定元素。列表索引从 0 开始记数!
set x { 1 2 3 }
结果=> 1 2 3
puts [lindex $x 1]
=>2
4.llength 命令
llength 命令可以获得一个列表内元素的个数。
set length “1 2 3 4 5”
结果=>1 2 3 4 5 ;#定义了一个字符串
set num [llength $l1] ;#这里 l1 被看作列表了
=>5
5.lrange 命令
lrange 命令返回一个指定区段的列表元素,可以以 end 或者 end-n 作为索引(n 为正整数)。
lrange {1 2 3 {4 5} 6} 2 end
结果=> 3 {4 5} 6
6.linsert 和 lreplace 命令
linsert 命令用来将元素插入到一个列表的由索引指定的位置。如果索引为 0 或者更小,则元素就会被添加到最前面。如果索引值大于或者等于列表长度,则元素被追加到列表尾部。
其他情况元素被添加到指定位置之前。 lreplace 命令将一个指定区段的列表元素替换为新元素。
如果没有指定新元素,则这个区域的元素就会被从列表中删除。注意:这两个操作不会改变原来列表的内容,而是返回一个新列表。
View Code
7.lsearch 命令
lsearch 命令在给定列表中搜索与匹配字符串匹配的元素,成功就返回正确的元素索引,否则返回-1。lsearch 支持通配符格式,但可以使用-exact 选项将其屏蔽而进行精确匹配。
set l1 [list This is one list]
结果=> This is one list
set index [lsearch $l1 l*]
结果=> 3
set index [lsearch -exact $l1 l*]
结果=>-1
set index [lsearch -exact $l1 list]
结果=>3
8.lsort 命令
lsort 命令实现对列表的排序。排序操作不影响原表,而是返回排序之后的新表。
set list “a Z z n100 n200 M p Hl hL m 1 20”
结果=>a Z z n100 n200 M p Hl hL m 1 20
lsort -ascii $list
结果=>1 20 Hl M Z a hL m n100 n200 p z
lsort -dictionary $list
结果=>1 20 a Hl hL M m n100 n200 p Z z
9. join 与 split 命令
join 命令接收一个列表,并用指定的分隔符将列表元素整合成一个字符串
join {1 {2 3} {4 5 6}} :
结果=> 1:2 3:4 5 6
split 命令的作用与 join 的作用相反,它接收一个字符串,并根据给定的字符将其分割转换成
一个列表。
set str cm8/auto/tools/aries/ASAM/NE/SNMP/IMPL/ne_create_board.tcl
结果=>cm8/auto/tools/aries/ASAM/NE/SNMP/IMPL/ne_create_board.tcl
set s /
结果=>/
set l1 [split $str $s]
结果=> cm8 auto tools aries ASAM NE SNMP IMPL ne_create_board.tcl
set l2 [split $str “/.”] ;#可以指定多个分割符
结果=> cm8 auto tools aries ASAM NE SNMP IMPL ne_create_board tcl
10.foreach 控制结构
foreach 命令/控制结构会遍历整个列表,逐次取出列表的每个元素的值放到指定变量中,使用者可以在跟随的过程体中添加必要的处理过程。
set lst “1 2 3 4”
结果是=>1 2 3 4
foreach l1 $lst {
puts $l1
}
结果是=>
1
2
3
4
例子:将一个
首先清空2个变量这2个变量是用来存放我们写出来的东西
1 2 | set CPU_MEM_LIBRARY_FILES_1P0V_BC "" set TOP_MEM_LIBRARY_FILES_1P0V_BC "" |
string length判断我们的字符串的长度
string equal -length $mem_length $mem $set_mem判断2个字符串的前mem_length位是否相等
如果判断成功我们将成功的值放入到一个变量中,
如果mem中所有的值都判断不成功,那么我们把他放入到另一个变量中
但是这里我不知道怎么将list中的一个量给删除,所以用了计次的方法计算32次(因为有32个值,mem中)
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 | ##build________TOP_MEM_LIBRARY_FILES_1P0V_BC foreach mem $mem_list { foreach set_mem $MEM_LIBRARY_FILES_1P0V_BC { set mem_length [string length $mem] set results [string equal -length $mem_length $mem $set_mem] if {$results == 1} { lappend TOP_MEM_LIBRARY_FILES_1P0V_BC $set_mem } } } ##build________CPU_MEM_LIBRARY_FILES_1P0V_BC set i 32 foreach set_mem $MEM_LIBRARY_FILES_1P0V_BC { foreach mem $mem_list { set mem_length [string length $mem] set results [string equal -length $mem_length $mem $set_mem] if {$results == 0} { set i [expr $i - 1] #lappend CPU_MEM_LIBRARY_FILES_1P0V_BC $set_mem } } if {$i == 0} { lappend CPU_MEM_LIBRARY_FILES_1P0V_BC $set_mem } else { } set i 32 } |