Я бы также использовал смещения. text 1 thru 2 of "xyz"
эквивалентно items 1 thru 2 of "xyz" as string
.
set x to "First Last (first.last@hotmail.com)"
set pos to offset of " (" in x
{text 1 thru (pos - 1) of x, text (pos + 2) thru -2 of x}
Насколько я знаю, вам не нужно восстанавливать разделители текстовых элементов .
set x to "First Last (first.last@hotmail.com)"
set text item delimiters to {" (", ")"}
set {fullname, email} to text items 1 thru 2 of x
Если другие искали манипуляции со строками в целом, вот методы замены и разбиения текста и объединения списков:
on replace(input, x, y)
set text item delimiters to x
set ti to text items of input
set text item delimiters to y
ti as text
end replace
on split(input, x)
if input does not contain x then return {input}
set text item delimiters to x
text items of input
end split
on join(input, x)
set text item delimiters to x
input as text
end join
Сравнение строк игнорирует регистр по умолчанию:
"A" is "a" -- true
"ab" starts with "A" -- true
considering case
"A" is "a" -- false
"ab" starts with "A" -- false
end considering
Реверсивный текст:
reverse of items of "esrever" as text
Вы можете использовать сценарий do shell, чтобы изменить регистр текста:
do shell script "printf %s " & quoted form of "aä" & " | LC_CTYPE=UTF-8 tr [:lower:] [:upper:]" without altering line endings
echo интерпретирует escape-последовательности по умолчанию в OS X / bin / sh. Вы также можете использовать shopt -u xpg_echo; echo -n
вместо printf %s
. LC_CTYPE=UTF-8
делает классы символов включающими некоторые не-ASCII символы. Если without altering line endings
пропущено, переводы строки заменяются на возврат каретки, а новая строка в конце вывода удаляется.
paragraphs of
разбивает строки вокруг \ n, \ r и \ r \ n. Он не снимает разделители.
paragraphs of ("a" & linefeed & "b" & return & "c" & linefeed)
-- {"a", "b", "c", ""}
В текстовой версии буфера обмена используются окончания строки CR. Это преобразует окончания строки в LF:
set text item delimiters to linefeed
(paragraphs of (get the clipboard as text)) as text
Unicode text
эквивалентно text
и string
с 10,5 :
Больше нет различий между Unicode и не-Unicode текстом. Существует ровно один текстовый класс с именем «text», то есть класс «foo» возвращает текст.