1s 8 като операции с низове. Нови функции за работа с низове

ЧАСТ 1. МЕТОДИ (26).

1.1. Основни методи (10). Независими, изградени на собствени прости алгоритми.

Page_Add() (дясно-ляво добавяне с определени знаци).

Page_Inverse () (инверсия - знаци от дясно на ляво).

Page_Codes() (кодове на знаци до ”,” и масив с кодове)

Page_Characters() (низ от кодове, разделени с ”,” или от масив с кодове)

Page_ReplaceSymbols() (замяна на някои символи с други).

String_FromArray() (низ от масив от фрагменти, разделени с разделител)

Page_FindIn() (търсене на подниз (включително вдясно) с указан номер на срещане).

Page_FindGr() (Търсене на група знаци, включени в посочения набор от знаци)

Page_FindNumber() (Търсене на число, включително вдясно с посочения номер на срещане)

Page_Interpret() (в масив, според установения синтаксис)

1.2. Производни методи (12). Всъщност това е използването на четири обобщени алгоритъмни метода (вижте част 2)

Page_Number() (от началото и от края на реда, не се „страхувайте“ от нецифрови знаци.

Page_Find() (търсене на подниз (включително нечувствителен към главни и малки букви и вдясно) с определен номер на срещане).

Page_Replace() (търсене (включително без значение за главни и малки букви и с дясна ръка) и замяна на разделителни поднизове).

String_Piece() (част от низ между посочените срещания на разделителя (ляв или десен)).

Page_ReplacePiece() (заменя “chunk” в изходния низ с посочения низ).

Page_ВArray() (между посочените срещания на разделителя (включително тези отдясно и без регистър).

Page_TransferBySyllables() (разделен на поднизове „Едва ли“, с тире).

Page_MoveByWords() (разделен на поднизове „Меко“)

Page_Cut() („Нарязване“ на поднизове с определени дължини)

Str_Shorten() (заменя лявата група от "съкратени" знаци с "низ за заместване"

Page_Abbreviation() (заменете дясната група от „намалени“ знаци с „низ за заместване“

Str_ShortenS() (замяна в средата на групата от „съкратени“ знаци с „низ за заместване“

Page_Extend (разширяване до определена дължина чрез увеличаване на броя на посочените знаци)

1.3. Подробни методи (3). "Разчленяване" на линия с прехвърляне към таблица с подробна информация.

Page_vTableIn() (в таблицата според системата от вложени разделители).

Page_vTableGr (към таблицата според многостепенен филтър).

Page_inTableNumbers (в таблица с числа и фрагменти между тях).

ЧАСТ 2. ОБОБЩЕНИ МЕТОДИ-АЛГОРИМИ (3).

Page_Occurrence() (методи „Намиране“ и „Замяна“).

Page_Fragments() (методи “Piece”, “ReplacePiece,”InArray”,”inTableIn”).

Page_Abcr() (методи "AbcrL", "AbcrP", "AbcrS", "Разгъване".

Page_Split() (методи „Преместване по срички“, „Преместване по думи“, „Изрязване“).

ЧАСТ 3. УНИВЕРСАЛНА ФУНКЦИЯ.

Това е един вид интерфейс за условно програмиране, който позволява

приложете няколко метода към низ наведнъж. Изпълнен като

функции със седем параметъра („Демо“ е изградено върху тази функция):

Страница_(методи, подметоди, вход, параметър1, параметър2, дължина_номер_позиция, допълнителен изход)

Настроики:

- “Методи” - няколко “комбинирани” и (или) един “изключителен” метод

(кодове или имена от един знак, възможно чрез ",")

- “Подметоди” - няколко “комбинирани” и (или) “изключителни” опции

“изключителен” метод (еднобуквени кодове или имена);

- “Вход” - Низ, или Масив или Таблица със стойности;

- “Param1” - низ за търсене, замествания, разделители, филтри;

- “Param2” - заместващ низ или знаци;

- “Length_Number_Position” - Число, Числа чрез разделител или масив с Числа;

- “Допълнителен изход” - Число или низ или масив или таблица със стойности;

Имена и/или едносимволни кодове на подметоди, както и номера в

(Length_Number_Position) може да бъде във всеки случай и отделен

някой от следните разделители: ”, :;”.

ЧАСТ 4. НЯКОЛКО ПРИМЕРИ.

Има NumbersInLine=(Str_FindNumber(InLine)<>Недефиниран);

Има числа в ред = (String_FindGr(Inline,"+0123456789")>0);

Има латински = (Str_FindGr(InStr, Str_Interpret("lL"))>0);

Има определени знаци = (Str_NfindGr(VxStr, "+to rogYu.0p9")>0);

IsNotPrinted=(Str_FindGr(InxStr, Line_Interpret("-l-L-r-R-P-Z-C"))>0);

ЧАСТ 5. ЗАКЛЮЧЕНИЕ.

Където беше възможно, се задоволявах с едно минаване по линията. Второто преминаване обикновено е на фрагменти. Не съм използвал вградената функция StrNumberOccurrences().

Използват се вградени функции: Left(), Right(), Middle(), StrLength()

- (позиционирането и получаването на част от линията трябва да бъде „бързо“).

Основните възможности на езика за програмиране обикновено включват работа с числа и низове. Обикновено тези характеристики са твърдо кодирани в кода на компилатора (или са внедрени „базовите“ класове на езика за програмиране).

В 1C възможността за работа с низове е програмирана в самата платформа. Днес ще разгледаме характеристиките на работата с 1C низове в програми на вградения език 1C.

Стойност на линията 1C

1. Да започнем с най-простото. Създаването на променлива и присвояването на постоянна стойност на низ изглежда така в 1C:

Променлива = "Здравей, свят!";

Ако трябва да зададете символ за кавички в постоянна стойност на 1C низ, тогава трябва да го удвоите ""

Променлива = "Здравей, свят"!;

2. Прекъсване на ред 1C може да бъде зададено по два начина едновременно. Първият е използването на символа |

Променлива = "Здравейте,
| свят! ";

Второто е използването на системното изброяване на символите. Тя ви позволява да добавяте както 1C прекъсвания на редове, така и други непечатаеми символи, като TAB.

Променлива = "Здравей" + Символи.PS + "мир!";

3. Конфигурациите в 1C могат да бъдат разработени не само за един език (руски, английски или друг) - но едновременно за няколко езика. В този случай текущият използван език е избран в долната част на прозореца 1C.

Списъкът с езици се намира в прозореца за конфигурация в клона Общи/Езици. Всеки език има кратък идентификатор като напр ruили инж.

Ясно е, че при програмиране на такава конфигурация 1C линиите също могат да бъдат многоезични. За да направите това, е възможно да създадете такава линия 1C, като посочите чрез; опции по езиков идентификатор:

Променлива = "ru=""Здравей, свят! ""; en=""Здравей, свят! """;

Ако използвате линията 1C, образувана по този начин, както обикновено, тогава ще бъде това, което е написано в нея. За да може системата да го раздели на две опции и да използва желаната, трябва да използвате функцията НStr():

//правилно за двуезични конфигурации
Доклад(NSr(Променлива));

Подпори с линия тип 1C

Атрибутът е поле в директорията/документа на 1C. Тя се различава от променлива в програма на езика 1C по това, че за атрибута е точно посочен нейният тип (число, 1C низ и т.н.). Ако трябва да опресните паметта си какво е реквизит, гледайте урока нататък.

Ако посочите типа атрибут - ред 1C, тогава трябва допълнително да посочите параметрите.

Редовете 1C се предлагат с неограничена дължина (посочена като дължина = 0) и ограничена дължина, указваща точния брой знаци. 1C редовете с неограничена дължина се съхраняват в отделна SQL таблица, така че използването им е по-малко продуктивно от ограничените.

Ето защо използването на 1C низове с неограничена дължина има своите ограничения - не е възможно да се използват навсякъде. Например не е позволено като номер на документ, референтен код или измерване.

Работа с 1C низове

Има няколко вградени функции на платформата 1C за работа с низове.

  • AbbrLP („Невероятно, но вярно!“)
    Премахва излишните интервали от реда 1C. Може също да се използва за конвертиране на всякакви типове в 1C низ (например числа).
  • Променлива = "Вася" + AbbrLP(" плюс") + "Оля"; //ще има "Вася плюс Оля"
    Пример за сумиране на няколко стойности на 1C низ. Резултатът ще бъде един ред 1C.
  • Променлива = Лев("Музика", 2); //ще бъде "Му"
    Променлива = Средна ("Музика", 2, 2); //ще има "заплаха"
    Променлива = Права ("Музика", 2); //ще има "ка"
    Различни опции за получаване на подниз от низ 1C.
  • Променлива = Find("Музика", "zy"); // ще има 3
    Търсене на подниз в низ 1C, започващ със знак 1.
  • Променлива = StrLength("Музика"); // ще има 6
    Връща броя знаци в реда 1C.
  • Доклад ("Здравей") // в прозореца за съобщения в долната част на прозореца 1C
    Alert("Hello") //изскачащ диалогов прозорец
    Status("Hello") //в реда за показване на състоянието долу вляво
    .

Привеждане на обекти в линия 1C

Както знаете, най-популярният формат за обмен на структурирана информация в момента е XML. Дори най-новата версия на MS Office Word и Excel запазва файлове в този формат (docx и xlsx, съответно, променете разширението на zip, отворете в архиватор).

Платформата 1C за обмен на данни предоставя няколко опции, основната от които също е XML.

1. Най-простият метод е да използвате функцията Abbreviation() или String(). Можете да използвате функцията REPRESENTATION() в тялото на заявката. Резултатът от тяхното действие е същият - те генерират низово представяне на всеки 1C обект за потребителя.

За директория по подразбиране това ще бъде нейното име. За документ – име, номер и дата на документа.

2. Всеки 1C обект (с ограничения) може да бъде конвертиран в XML и обратно. Процесът на преобразуване се нарича сериализация.

StringViewXml = XMLString(стойност); //вземете XML от 1C стойност
Value1C = XMLValue(Type("DirectoryLink.Nomenclature"),TypeStringXml); //вземете 1C стойността от XML низа, трябва да посочите типа 1C, който трябва да бъде получен

3. Има собствен начин на платформата 1C за конвертиране на всеки 1C обект в низ. Мигрира от версия 1C 7.7. Този формат не се разбира от други програми, но други 1C го разбират, което улеснява използването му за обмен между 1C бази данни.

Ред = ValueInRowInt(Value1C); //вземете низ 1C от стойност 1C
ValueVFile("C:\MyFile.txt", Value1C); // друга опция, получаваме файл със записан низ от стойността 1C
Value1C = ValueFromStringInt(String); //назад от ред 1C
Value1C = ValueFile("C:\MyFile.txt"); //назад от файл

Редактиране на 1C линии във формуляра

В допълнение към работата с 1C низове в програма на езика 1C, разбира се, бих искал потребителят да може да ги редактира. Има няколко възможности за това:

1. Най-лесният начин е да поискате въвеждането на линия 1C при поискване. Този метод се използва при преподаване на 1C програмиране; в живота се използва много по-рядко (но се използва!).

Променлива = "";
Ред = EnterValue(Променлива, "Въведете пълно име");

2. За да се покажат подробности за 1C обект (директория/документ) или подробности за формуляр (вижте), най-често се използва поле за въвеждане. Това е най-разпространеният инструмент в 1C за потребителя да работи с полета за редактиране.

3. Възможностите на полето за въвеждане могат да бъдат разширени (вижте свойствата на полето за въвеждане, щракнете с десния бутон върху него, повече подробности):

  • Квадратче за отметка Многоредов режим на редактиране
  • Квадратче за отметка за разширено редактиране (достъпно, ако предишното квадратче за отметка е отметнато)
  • Квадратче за отметка Режим на парола (вижте).

4. Ако всички възможности на полето за въвеждане не са ви достатъчни, има вграден редактор. За да го добавите към формуляра, трябва да добавите поле за текстов документ към менюто Form/Insert Control. В свойствата му можете да посочите режима му на работа – свойството Разширение.

Поле на текстов документ не може да бъде свързано директно с данни. Необходимо е да напишете функция в манипулатора на събитие OnOpen() на формата (вижте):

Form Elements.ElementNameTextDocumentField.SetText(StringValue); //тук ValueString е текстът, получен например от атрибута

И в манипулатора за запазване - например в бутона Запазване - добавете запис:

ValueString = FormElements.ElementNameTextDocumentField.GetText(); //Стойност Редът тук е атрибутът, където запазваме стойността

5. В 1C версия 8.2.11 в управляваните форми се появи нова опция за представяне на 1C линия - полето Форматиран документ.


Подобно на полето на текстов документ, трябва да го зададете при отварянето му и да го запишете, когато го запазвате сами с помощта на програмата.

  • В обекта 1C, чиято форма създаваме (директория, документ, обработка и т.н.) - добавете атрибут с тип Съхранение на стойност
  • Във функцията OnReadOnServer() задаваме текста от атрибута

    // тук Атрибутът е добавеният атрибут на 1C обекта
    //тук FormattedDocument е името на полето във формата за редактиране
    &На сървъра

    FormattedDocument = CurrentObject.Attributes.Get();
    Край на процедурата

  • Във функцията BeforeWritingOnServer() или чрез бутона ще напишем текста от полето

    &На сървъра
    Процедура при четене на сървър (текущ обект)
    CurrentObject.Props = NewValueStorage(FormattedDocument);
    Край на процедурата

Типът String се среща във всички езици за програмиране. Той е примитивен и в 1C има много функции за работа с него. В тази статия ще разгледаме подробно различни начини за работа с типове низове в 1C 8.3 и 8.2, като използваме примери.

Линия

За да конвертирате променлива от всякакъв тип в низ, има функция със същото име „String()“. Входният параметър ще бъде самата променлива, чието низово представяне трябва да бъде получено.

String(False) // връща "Не"
String(12345) // връща "12 345"
Низ(CurrentDate()) //"07/21/2017 11:55:36″

Възможно е да се преобразуват не само примитивни типове в низ, но и други, например елементи на директории и документи.

SokrLP, SokrL, SokrP

Входните параметри на тези функции са променлива от низов тип. Функциите премахват незначещите знаци (интервали, връщане на каретка и т.н.): съответно от лявата и дясната страна, само от лявата страна и само отдясно.

Съкращение (" Интервалите ще бъдат премахнати от двете страни ") // "Интервалите ще бъдат премахнати от двете страни"
Abbreviation(" Интервалите от двете страни ще бъдат премахнати ") // " Интервалите отляво ще бъдат премахнати "
Съкращение (" Интервалите от двете страни ще бъдат премахнати ") // " Интервалите отдясно ще бъдат премахнати "

Лъв, десен, среден

Тези функции ви позволяват да изрежете част от низ. Функцията "Left()" ще върне частта от низ от лявата му страна на указаната дължина. Функцията "Right()" е подобна, но изрязва отдясно. Функцията “Avg()” ви позволява да посочите номера на знака, от който ще бъде избран редът и неговата дължина.

Lev("Променлива на низ", 4) // връща "Str"
Right("Променлива на низ", 7) // връща "променлива"
Medium("String variable", 2, 5) // връща "troco"

StrLength

Функцията определя броя на символите, които се съдържат в низова променлива.

StrLength("Word") // резултатът от изпълнението ще бъде числото 5

намирам

Функцията дава възможност да се търси част от низ в низова променлива. Върнатата стойност ще бъде число, което показва позицията на началото на намерения низ. Ако не бъде намерено съвпадение, се връща нула.

Моля, обърнете внимание, че търсенето е чувствително към главни и малки букви. Ако има повече от едно срещане на подниза за търсене в оригиналния низ, функцията ще върне началото на първото срещане.

Find("one, two, one, two, three", "two") // функцията ще върне числото 6

Празен ред

Използването на тази функция ви позволява да определите дали даден низ е празен. Второстепенни символи като интервал, връщане на каретка и други не се вземат предвид.

EmptyString("Pupkin Vasily Ivanovich") // функцията ще върне стойността False
EmptyString(" ") // функцията ще върне стойността True

VReg, NReg, TReg

Тези функции са много полезни при сравняване и конвертиране на низови променливи. „Vreg()“ ще върне оригиналния низ с главни букви, „HPreg()“ с малки букви, а „TReg()“ ще го форматира така, че първият знак на всяка отделна дума да е с главни букви, а всички следващи знаци са с главни букви.

VReg("ГЕНЕРАЛЕН ДИРЕКТОР") // върната стойност - "ГЕНЕРАЛЕН ДИРЕКТОР"
NReg(“CEO DIRECTOR”) // върната стойност – “CEO”
TREG(“CEO DIRECTOR”) // върната стойност – “Генерален директор”

PageReplace

Тази функция е аналогична на замяната в текстови редактори. Тя ви позволява да замените един знак или набор от знаци с друг в низови променливи.

StrReplace("red, white, yellow", ","", ";") // връща "red; бяло; жълт"

StrNumberLines

Функцията ви позволява да определите броя на редовете, разделени с връщане на каретка в текстова променлива.

Цикълът в примера по-долу ще премине през три кръга, защото функцията LineNumberRow ще върне стойността 3:

За ind = 1 по StrNumber от низове ("Line1" + Symbols.PS + "Line2" + Symbols.PS + "Line3") Цикъл
<тело цикла>
EndCycle;

StrGetString

Тази функция работи с многоредов текст по същия начин като предишната. Позволява ви да получите конкретен низ от текстова променлива.

StrGetString("Низ1" + Знаци.PS + "Низ2" + Знаци.PS + "Низ3", 2) // върне "String2"

PageNumberOccurrences

Функцията отчита броя на срещанията на знак или подниз в търсения низ.

StrNumberAttachments("a;b;c;d; ", ";") // функцията ще върне числото 4

Символ и символен код

Тези функции ви позволяват да получите знак по неговия код в Unicode кодирането, както и да определите този код по самия символ.

SymbolCode("A") // функцията ще върне числото 1040
CharacterCode(1040) // функцията ще върне „A“

Често срещани задачи при работа с низове

Конкатениране на низове

За да комбинирате няколко низа (за да извършите конкатенация), е достатъчно да използвате оператора за добавяне.

„Ред 1″ + „Ред 2″ //резултатът от добавянето на два реда ще бъде „Ред 1 Ред 2“

Тип преобразуване

За да конвертирате тип в низ, например връзка към елемент от директория, номер и т.н., е достатъчно да използвате функцията „String()“. Функции като „ScrLP()“ също ще преобразуват променливи в низ, но незабавно с отрязване на незначителните знаци.

String(1000) // връща "1000"

Моля, обърнете внимание, че когато преобразувате число в низ, програмата автоматично добавя интервал, разделящ хилядата. За да избегнете това, можете да използвате следните конструкции:

StrReplace(String(1000),Characters.NPP,"") // връща "1000"

String(Format(1000,"HG=")) // връща "1000"

Кавички в низ

Доста често ще трябва да се справяте с необходимостта да посочите кавички в низова променлива. Това може да бъде или текстът на заявката, написан в конфигуратора, или просто променлива. За да разрешите този проблем, просто трябва да поставите две кавички.

Header = String("Horns and Hooves LLC - това сме ние!") // ще върне "Horns and Hooves LLC - това сме ние!"

Многоредов, нов ред

За да създадете многоредов текст, просто добавете нови редове (Symbols.PS) към него.

MultilineText = „Първи ред“ + Symbols.PS + „Втори ред“

Как да премахнете интервали

За да премахнете интервалите отдясно или отляво, можете да използвате функцията „ScrAP()“ (както и „ScrL()“ и „ScrP()“):

StringNoSpaces = Abbreviation(" Много букви ") // функцията ще върне стойността "Много букви"

Ако след преобразуването на число в низ трябва да премахнете неразделящите се интервали, използвайте следната конструкция:

StringNoSpaces = StrReplace(String(99999),Characters.NPP,"") // връща "99999"

Програмистите също често използват следната конструкция, която ви позволява да премахнете или замените с друг знак всички интервали в текстова променлива:

StringNoSpaces = StrReplace("hello","") // връща "hello"

Сравняване на низове един с друг

Можете да сравнявате термини с обичайния знак за равенство. Сравнението е чувствително към главни и малки букви.

"Hello" = "hello" // връща False
"Hello" = "Hello" // връща True
„Здравей“ = „Довиждане“ // ще върне False

Има няколко механизма за работа с низове в 1C заявки. Първо могат да се добавят линиите. Второ, можете да вземете подниз от низ. Трето, низовете могат да се сравняват, включително по модел. Това вероятно е всичко, което може да се направи с низове.

Добавяне на низове

За добавяне на редове в заявка се използва операцията „+“. Можете да добавяте само низове с ограничена дължина.

ИЗБЕРЕТЕ "Име: " + Име на контрагенти 1 от директория КАТО контрагенти WHERE Връзка

Поднизова функция

ПОДНИЗ(<Строка>, <НачальнаяПозиция>, <Длина>)

Аналог на функцията Environment() от обектния модел. Функцията Substring() може да се приложи към низови данни и ви позволява да изберете фрагмент <Строки> , започвайки с номера на знака <НачальнаяПозиция> (знаците в ред се номерират от 1) и дължина <Длина> герои. Резултатът от изчислението на функцията има тип низ с променлива дължина и дължината ще се счита за неограничена, ако <Строка> има неограничена дължина и параметър <Длина> не е константа или по-голямо от 1024.

Ако дължината на низа е по-малка от зададената във втория параметър, тогава функцията ще върне празен низ.

внимание!Не се препоръчва използването на функцията SUBSTRING() за преобразуване на низове с неограничена дължина в низове с ограничена дължина. Вместо това е по-добре да използвате cast оператора EXPRESS().

Функция Подобна

Ако трябва да се уверим, че атрибут на низ отговаря на определени критерии, ние го сравняваме:

ИЗБЕРЕТЕ Контрагенти КАТО Колона 1 ОТ Указател КАТО Контрагенти WHERE Име = "Газпром".

Но какво ще стане, ако имате нужда от по-фино сравнение? Не просто равенство или неравенство, а сходство с определен модел? Точно за това е създадена функцията SIMILAR.

LIKE — Оператор за проверка на низ за сходство с модел. Аналог на LIKE в SQL.

Операторът SIMILAR ви позволява да сравните стойността на израза, посочен вляво от него, с низа на модела, посочен вдясно. Стойността на израза трябва да е от тип низ. Ако стойността на израза съвпада с шаблона, резултатът от оператора ще бъде TRUE, в противен случай ще бъде FALSE.

Следните знаци в низа на шаблона са служебни и имат значение, различно от символа на низа:

  • % (процент): последователност, съдържаща произволен брой произволни знаци;
  • _ (долна черта): един произволен знак;
  • […] (един или повече знаци в квадратни скоби): всеки отделен знак, посочен в квадратните скоби. Изброяването може да съдържа диапазони, например a-z, което означава произволен знак, включен в диапазона, включително краищата на диапазона;
  • [^...] (в квадратни скоби знак за отрицание, последван от един или повече знака): всеки отделен знак, различен от изброените след знака за отрицание.

Всеки друг символ означава себе си и не носи никакво допълнително натоварване. Ако един от изброените знаци трябва да бъде написан като себе си, тогава той трябва да бъде предшестван от<Спецсимвол>. себе си<Спецсимвол>(всеки подходящ знак) се дефинира в същия израз след ключовата дума SPECIAL CHARACTER.

Внедрено във версия 8.3.6.1977.

Разширихме набора от функции, предназначени за работа с низове. Направихме това, за да ви предоставим по-усъвършенствани инструменти за анализиране на низови данни. Новите функции ще бъдат удобни и полезни при технологични задачи за анализ на текст. В задачи, свързани с анализиране на текст, който съдържа данни във форматирана форма. Това може да бъде анализ на някои файлове, получени от оборудването, или например анализ на технологичен дневник.

Бихте могли да извършвате всички действия, които изпълняват нови функции преди. Използване на повече или по-малко сложни алгоритми, написани на вграден език. Следователно новите функции не ви дават принципно нови възможности. Те обаче ви позволяват да намалите количеството код и да направите кода по-опростен и разбираем. В допълнение, те ви позволяват да ускорите изпълнението на действията. Тъй като функциите, внедрени в платформата, работят, разбира се, по-бързо от подобен алгоритъм, написан на вграден език.

Функция за форматиране StrTemplate()

Тази функция замества параметри в низ. Необходимостта от такова преобразуване често възниква, например, когато се показват предупредителни съобщения. Синтаксисът за тази функция е както следва:

StrTemplate(<Шаблон>, <Значение1-Значение10>)

<Шаблон>- това е низът, в който трябва да замените представянията на параметрите.

<Значение1> , ... <Значение10>- това са параметри (максимум десет), чиито представяния трябва да бъдат заместени в низа.

За да посочите конкретно място в шаблона, където искате да извършите заместването, трябва да използвате маркери като %1, ... %10. Броят на маркерите, включени в шаблона, и броят на параметрите, съдържащи стойности, трябва да съвпадат.

Например резултатът от изпълнението на такъв оператор:

ще има ред:

Грешка в данните на ред 2 (изисква се тип дата)

Функция за работа с низове StrCompare()

Тази функция сравнява два низа без значение за главни и малки букви. Например така:

Можете да извършите същото действие по-рано, като използвате обекта за сравнение на стойности:

Използването на новата функция обаче изглежда по-лесно. И освен това, функцията, за разлика от обекта за сравнение на стойности, работи както в тънкия клиент, така и в уеб клиента.

Функции за работа с низове StrStartsWith(), StrEndsAt()

Тези функции определят дали даден низ започва с определен подниз или дали низът завършва с определен подниз. Алгоритъмът за тези функции не е труден за внедряване във вграден език, но тяхното присъствие ви позволява да пишете по-чист и по-разбираем код. И работят по-бързо.

Например, те са удобни за използване в израза If:

Функции за работа с низове StrDivide(), StrConnect()

Тези функции разделят низ на части с помощта на определен разделител. Или обратното, те комбинират няколко реда в един, като вмъкват избрания разделител между тях. Те са удобни за създаване или анализ на дневници и технологични дневници. Например, можете лесно да анализирате запис в технологичен дневник на части, подходящи за по-нататъшен анализ:

Функция за работа с низове StrFind()

Вместо старата функция Find(), внедрихме нова функция, която има допълнителни възможности:

  • Търсене в различни посоки (от началото, от края);
  • Търсене от определена позиция;
  • Търсене на събитие с определен номер (второ, трето и т.н.).

Всъщност тя дублира възможностите на старата функция. Това се прави, за да се поддържа съвместимост с модули, компилирани в по-стари версии. Препоръчително е вече да не използвате старата функция Find().

По-долу е даден пример за използване на новите възможности за търсене. Обратното търсене е полезно, когато имате нужда от последната част от формализиран низ, като например пълното име на файл в URL. И търсенето от определена позиция помага в случаите, когато трябва да търсите в известен фрагмент, а не в целия ред.