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