Tcl - Строки
Примитивным типом данных Tcl является строка, и часто мы можем найти кавычки на Tcl как на строковом языке. Эти строки могут содержать буквенно-цифровые символы, только числа, логические или даже двоичные данные. Tcl использует 16-битные символы Юникода, а буквенно-цифровые символы могут содержать буквы, включая нелатинские символы, числа или знаки препинания.
Логическое значение может быть представлено как 1, да или истина для истины и 0, нет или ложь для ложи.
Строковые представления
В отличие от других языков, в Tcl вам не нужно включать двойные кавычки, если это всего лишь одно слово. Примером может быть -
#!/usr/bin/tclsh
set myVariable hello
puts $myVariable
Когда приведенный выше код выполняется, он дает следующий результат:
hello
Когда мы хотим представить несколько строк, мы можем использовать двойные кавычки или фигурные скобки. Это показано ниже -
#!/usr/bin/tclsh
set myVariable "hello world"
puts $myVariable
set myVariable {hello world}
puts $myVariable
Когда приведенный выше код выполняется, он дает следующий результат:
hello world
hello world
Последовательность выхода строки
Символьный литерал может быть простым символом (например, 'x'), escape-последовательностью (например, '\ t') или универсальным символом (например, '\ u02C0').
В Tcl есть определенные символы, которым предшествует обратная косая черта, они будут иметь особое значение и используются для обозначения новой строки (\ n) или табуляции (\ t). Здесь у вас есть список некоторых таких кодов escape-последовательностей -
Последовательность выхода | Имея в виду |
---|---|
\\ | \ персонаж |
\ ' | ' персонаж |
\ " | " персонаж |
\? | ? персонаж |
\ а | Оповещение или звонок |
\ b | Backspace |
\ f | Подача формы |
\ п | Новая линия |
\р | Возврат каретки |
\ т | Горизонтальная вкладка |
\ v | Вертикальная табуляция |
Ниже приведен пример, показывающий несколько символов escape-последовательности.
#!/usr/bin/tclsh
puts "Hello\tWorld\n\nTutorialspoint";
Когда приведенный выше код компилируется и выполняется, он дает следующий результат:
Hello World
Tutorialspoint
Строковая команда
Список подкоманд для строковой команды приведен в следующей таблице -
Sr.No. | Методы и описание |
---|---|
1 | compare строка1 строка2 Лексографически сравнивает строку1 и строку2. Возвращает 0, если равно, -1, если строка1 предшествует строке2, иначе 1. |
2 | first строка1 строка2 Возвращает индекс первого вхождения строки1 в строку2. Если не найден, возвращает -1. |
3 | index строковый индекс Возвращает символ по индексу. |
4 | last строка1 строка2 Возвращает индекс последнего вхождения строки1 в строку2. Если не найден, возвращает -1. |
5 | length строка Возвращает длину строки. |
6 | match pattern строка Возвращает 1, если строка соответствует шаблону. |
7 | range строка index1 index2 Вернуть диапазон символов в строке от index1 до index2. |
8 | tolower строка Возвращает строку в нижнем регистре. |
9 | toupper строка Возвращает строку в верхнем регистре. |
10 | trim строка? обрезать символы? Удаляет символы обрезки на обоих концах струны. Символы обрезки по умолчанию - это пробелы. |
11 | trimleft строка? обрезать символы? Удаляет символы обрезки в левом начале строки. Символы обрезки по умолчанию - это пробелы. |
12 | trimright строка? обрезать символы? Удаляет символы обрезки в левом конце строки. Символы обрезки по умолчанию - это пробелы. |
13 | wordend индекс findstring Возвращает индекс в строке поиска символа после слова, содержащего символ в индексе. |
14 | wordstart индекс findstring Возвращает индекс в строке поиска первого символа в слове, содержащем символ в индексе. |
Примеры некоторых часто используемых строковых подкоманд Tcl приведены ниже.
Сравнение строк
#!/usr/bin/tclsh
set s1 "Hello"
set s2 "World"
set s3 "World"
puts [string compare $s1 $s2]
if {[string compare $s2 $s3] == 0} {
puts "String \'s1\' and \'s2\' are same.";
}
if {[string compare $s1 $s2] == -1} {
puts "String \'s1\' comes before \'s2\'.";
}
if {[string compare $s2 $s1] == 1} {
puts "String \'s2\' comes after \'s1\'.";
}
Когда приведенный выше код компилируется и выполняется, он дает следующий результат:
-1
String 's1' and 's2' are same.
String 's1' comes before 's2'.
String 's2' comes after 's1'.
Индекс строки
#!/usr/bin/tclsh
set s1 "Hello World"
set s2 "o"
puts "First occurrence of $s2 in s1"
puts [string first $s2 $s1]
puts "Character at index 0 in s1"
puts [string index $s1 0]
puts "Last occurrence of $s2 in s1"
puts [string last $s2 $s1]
puts "Word end index in s1"
puts [string wordend $s1 20]
puts "Word start index in s1"
puts [string wordstart $s1 20]
Когда приведенный выше код компилируется и выполняется, он дает следующий результат:
First occurrence of o in s1
4
Character at index 0 in s1
H
Last occurrence of o in s1
7
Word end index in s1
11
Word start index in s1
6
Длина строки
#!/usr/bin/tclsh
set s1 "Hello World"
puts "Length of string s1"
puts [string length $s1]
Когда приведенный выше код компилируется и выполняется, он дает следующий результат:
Length of string s1
11
Обработка случаев
#!/usr/bin/tclsh
set s1 "Hello World"
puts "Uppercase string of s1"
puts [string toupper $s1]
puts "Lowercase string of s1"
puts [string tolower $s1]
Когда приведенный выше код компилируется и выполняется, он дает следующий результат:
Uppercase string of s1
HELLO WORLD
Lowercase string of s1
hello world
Обрезка символов
#!/usr/bin/tclsh
set s1 "Hello World"
set s2 "World"
puts "Trim right $s2 in $s1"
puts [string trimright $s1 $s2]
set s2 "Hello"
puts "Trim left $s2 in $s1"
puts [string trimleft $s1 $s2]
set s1 " Hello World "
set s2 " "
puts "Trim characters s1 on both sides of s2"
puts [string trim $s1 $s2]
Когда приведенный выше код компилируется и выполняется, он дает следующий результат:
Trim right World in Hello World
Hello
Trim left Hello in Hello World
World
Trim characters s1 on both sides of s2
Hello World
Соответствующие строки
#!/usr/bin/tclsh
set s1 "[email protected]"
set s2 "*@*.com"
puts "Matching pattern s2 in s1"
puts [string match "*@*.com" $s1 ]
puts "Matching pattern tcl in s1"
puts [string match {tcl} $s1]
Когда приведенный выше код компилируется и выполняется, он дает следующий результат:
Matching pattern s2 in s1
1
Matching pattern tcl in s1
0
Добавить команду
#!/usr/bin/tclsh
set s1 "Hello"
append s1 " World"
puts $s1
Когда приведенный выше код компилируется и выполняется, он дает следующий результат:
Hello World
Команда форматирования
В следующей таблице показан список спецификаторов формата, доступных в Tcl -
Спецификатор | Использовать |
---|---|
% s | Строковое представление |
% d | Целочисленное представление |
% f | Представление с плавающей запятой |
% e | Представление с плавающей запятой с мантиссой-экспонентой |
%Икс | Шестнадцатеричное десятичное представление |
Ниже приведены несколько простых примеров -
#!/usr/bin/tclsh
puts [format "%f" 43.5]
puts [format "%e" 43.5]
puts [format "%d %s" 4 tuts]
puts [format "%s" "Tcl Language"]
puts [format "%x" 40]
Когда приведенный выше код компилируется и выполняется, он дает следующий результат:
43.500000
4.350000e+01
4 tuts
Tcl Language
28
Команда сканирования
Команда сканирования используется для синтаксического анализа строки на основе спецификатора формата. Ниже приведены некоторые примеры.
#!/usr/bin/tclsh
puts [scan "90" {%[0-9]} m]
puts [scan "abc" {%[a-z]} m]
puts [scan "abc" {%[A-Z]} m]
puts [scan "ABC" {%[A-Z]} m]
Когда приведенный выше код компилируется и выполняется, он дает следующий результат:
1
1
0
1