Нові функції роботи з рядками. Нові функції роботи з рядками Робота з рядком 1с

Рядки в 1С 8.3 у вбудованій мові 1с є значенням примітивного типу Рядок. Значення цього типу містять рядок у форматі Unicode довільної довжини. Змінні рядкового типу є набором символів ув'язнених у лапки.

Приклад 1. Створимо рядкову змінну тексту.

Рядкова Змінна = "Привіт світ!";

Функції роботи з рядками 1с 8.3

У цьому розділі будуть наведені основні функції, що дозволяють змінювати рядки в 1с, або аналізувати інформацію, що міститься в них.

СтрДліна

СтрДліна(<Строка>) . Повертає кількість символів, що містяться в рядку, переданому у параметрі.

Приклад 2. Порахуємо кількість символів у рядку "Привіт мир!".

Рядок = "Привіт світ!"; КількістьСимволів = СтрДліна(Рядок); Повідомити (Кількість Символів);

Результатом виконання цього коду буде виведення на екран кількості символів рядка: 11.

СокрЛ

СокрЛ(<Строка>) . Відсікає незначні символи, що стоять ліворуч від першого символу в рядку.
Незначні символи:

  • пробіл;
  • нерозривна прогалина;
  • табуляція;
  • повернення каретки;
  • переклад рядка;
  • переклад форми (сторінки).

Приклад 3. Прибрати усі прогалини з лівого боку рядка світ! та приєднати до неї рядок "Привіт".

Рядок = СокрЛ ("світ!"); Рядок = "Привіт" + Рядок; Повідомити(Рядок);

Підсумком виконання цього коду буде виведення на екран рядка "Привіт мир!".

СокрП

СокрП(<Строка>) . Відсікає незначні символи, що стоять праворуч від першого символу в рядку.

Приклад 4. Сформувати з рядків "Привіт" та "світ!" фразу «Привіт світ!»

Рядок = СокрП("Привіт")+"+СокрЛ("світ!"); Повідомити(Рядок);

СокрЛП

СокрЛП(<Строка>) . Відсікає незначні символи, що стоять праворуч від першого символу в рядку, також відсікає незначні символи, що стоять ліворуч від першого символу в рядку. Ця функція використовується частіше за попередні два, оскільки вона більш універсальна.

Приклад 5. Прибрати незначні символи ліворуч і праворуч у найменуванні контрагента.

Контрагент = Довідники.Контрагенти.ЗнайтиПоРеквізиту("ІПН", "0777121211"); КонтрагентОб'єкт = Контрагент.Отримати Об'єкт (); Контрагент Об'єкт. Найменування = СокрЛП (Контрагент Об'єкт. Найменування); КонтрагентОб'єкт. Записати ();

Лев

Лев(<Строка>, <ЧислоСимволов>) . Отримує перші символи рядка, кількість символів вказується у параметрі Число символів.

Приклад 6. Нехай у структурі Співробітникутримуватися ім'я, прізвище та по батькові співробітника. Отримати рядок із прізвищем та ініціалами.

ІніціалІмені = Лев(Співробітник.Ім'я, 1); Ініціал Батьківщини = Лев (Співробітник. По-батькові, 1); Повне Ім'я = Співробітник. Прізвище + " " + Ініціал Імені + "." + Ініціатив Батьківщини + ".";

Має рацію

Прав(<Строка>, <ЧислоСимволов>) . Отримує останні символи рядка, кількість символів вказується у параметрі Число символів.Якщо вказана кількість символів перевищує довжину рядка, то повертається весь рядок.

Приклад 7. Нехай наприкінці рядкової змінної записано дату у форматі «ггггммдд», отримати рядок з датою та перетворити її на тип Дата.

Рядок = "Поточна дата: 20170910"; РядокДата = Прав(Рядок, 8); Дата = Дата (РядокДата);

Середовище

Середовище<Строка>, <НачальныйНомер>, <ЧислоСимволов>) . Отримує підрядок із рядка переданого у параметрі Рядок, починаючи з символу, номер якого вказаний у параметрі ПочатковийНомерта довжиною переданої у параметр Число символів.Нумерація символів у рядку починається з 1. Якщо у параметрі ПочатковийНомервказано значення, менше або дорівнює нулю, параметр приймає значення 1. Якщо параметр Число символівне вказано, вибираються символи до кінця рядка.

Приклад 8. Нехай у рядковій змінній, починаючи з дев'ятої позиції, міститься код регіону, слід отримати його та записати в окремий рядок.

Рядок = "Регіон: 99 р. Москва"; Регіон = Середовище (Рядок, 9, 2);

СтрНайти

СтрНайти(<Строка>, <ПодстрокаПоиска>, <НаправлениеПоиска>, <НачальнаяПозиция>, <НомерВхождения>) . Здійснює пошук зазначеного підрядка у рядку, повертає номер позиції першого символу знайденого підрядка. Розглянемо параметри цієї функції:

  • Рядок. Вихідний рядок;
  • ПідрядкаПошук. Шуканий підряд;
  • Напрям Пошуку. Вказує напрямок пошуку підрядка у рядку. Може приймати значення:
    • НапрямокПошуку.Спочатку;
    • Напрямок Пошуку.;
  • ПочатковаПозиція. Вказує позицію у рядку, з якого починається пошук;
  • НомерВходження. Вказує номер входження шуканого підрядка у вихідному рядку.

Приклад 9. У рядку "Привіт мир!" визначити позицію останнього входження символу "і".

НомерПозиції = СтрНайти("Привіт світ!", "і", НапрямПошуку.Сконця); Повідомити(НомерПозиції);

Результатом виконання цього коду буде виведення на екран номера останнього входження символу «і»: 9.

ВРег

ВРег(<Строка>) . Перетворює всі символи вказаного рядка в 1з8 до верхнього регістру.

Приклад 10. Перетворити рядок "Привіт світ!" до верхнього регістру.

РядокВрег = ВРег("привіт світ!"); Повідомити(РядокВрег);

Підсумком виконання цього коду буде виведення на екран рядка «ПРИВІТ СВІТ!»

НРег

НРег(<Строка>) . Перетворює всі символи вказаного рядка в 1с 8 до нижнього регістру.

Приклад 11. Перетворити рядок «ПРИВІТ СВІТ!» до нижнього регістру.

РядокНрег = НРег("ПРИВІТ СВІТ!"); Повідомити (Рядок);

Підсумком виконання цього коду буде виведення на екран рядка «Привіт світ!»

трег

трег(<Строка>) . Перетворює рядок наступним чином: перший символ кожного слова переводиться у верхній регістр, решта символів слова перетворюється на нижній регістр.

Приклад 12. Зробити великими перші літери слів у рядку «Привіт світ!».

РядокТрег = ТРег("привіт світ!"); Повідомити(РядокТрег);

Підсумком виконання цього коду буде виведення на екран рядка "Привіт Світ!"

Символ

Символ(<КодСимвола>) . Отримує символ за кодом кодування Unicod.

Приклад 13. Додамо ліворуч та праворуч у рядок «Привіт Мир!» символ ★

РядокЗі зірками = Символ("9733")+"Привіт Світ!"+Символ("9733"); Повідомити (Рядок зі Зірками);

Підсумком виконання цього коду буде виведення на екран рядка «Привіт Мир!★»

КодСимволу

КодСимволу(<Строка>, <НомерСимвола>) . Отримує код символу в кодуванні Unicode з рядка, зазначеного в першому параметрі, розташованого в позиції, зазначеній у другому параметрі.

Приклад 14. Дізнатися код останнього символу у рядку "Привіт Мир!".

Рядок = "Привіт Світ!"; КодСимволу = КодСимволу(Рядок, СтрДліна(Рядок)); Повідомити(КодСимволу);

Підсумком виконання цього коду буде виведення на екран коду символу "!" - 33.

Порожня стрічка

Порожня стрічка(<Строка>) . Перевіряє, чи складається рядок лише з незначних символів, тобто чи є він порожнім.

Приклад 15. Перевірити чи порожній рядок складається з трьох пробілів.

Порожня = ПорожняРядок(" "); Повідомити(Порожня);

Результатом виконання цього коду буде виведення на екран слова «Так» (рядковий вираз логічного значення Істина).

СтрЗамінити

Стр Замінити (<Строка>, <ПодстрокаПоиска>, <ПодстрокаЗамены>) . Знаходить у вихідному рядку всі входження підрядка пошуку та замінює її на підрядок заміни.

Приклад 16. У рядку "Привіт Мир!" замінити слово "Світ" на слово "Друзі".

Рядок = СтрЗаменить("Привіт Світ!", "Світ", "Друзі"); Повідомити(Рядок);

Підсумком виконання цього коду буде виведення на екран рядка "Привіт Друзі!"

СтрЧислоРядок

СтрЧислоРядок(<Строка>) . Дозволяє порахувати кількість рядків у рядковому рядку. Для переходу на новий рядок 1с 8 використовується символ ПС(Символ перекладу рядка).

Приклад 17. Визначити кількість рядків у тексті:
«Перший рядок
Другий рядок
Третій рядок»

Число = СтрЧіслоРядок("Перший рядок"+Символи.ПС +"Другий рядок"+Символи.ПС +"Третій рядок"); Повідомити (Число);

Результатом виконання цього коду буде виведення на екран кількості рядків у тексті: 3

СтрОтриматиРядок

СтрОтриматиРоку(<Строка>, <НомерСтроки>) . Отримує рядок у рядковому рядку за його номером. Нумерація рядків починається з першого.

Приклад 18. Отримати останній рядок у тексті:
«Перший рядок
Другий рядок
Третій рядок»

Текст = "Перший рядок" + Символи. ПС + "Другий рядок" + Символи. ПС + "Третій рядок"; ОстанняРядок = СтрОтриматиРоку(Текст, СтрЧислоРядок(Текст)); Повідомити(ОстанняРядок);

Підсумком виконання цього коду буде виведення на екран рядка "Третій рядок".

СтрЧіслоВходжень

СтрЧИСЛОВХОДЖЕНЬ(<Строка>, <ПодстрокаПоиска>) . Повертає кількість входжень зазначеного підрядка в рядок. Функція чутлива до регістру.

Приклад 19. Визначити скільки разів входить до рядка «Рядки в 1с 8.3 і 8.2» буква «с», незалежно від її регістру.

Рядок = "Рядки в 1с 8.3 та 8.2"; ЧислоВходжень = СтрЧіслоВходінь(Врег(Рядок), "С"); Повідомити (ЧислоВходжений);

Результатом виконання цього коду буде виведення на екран числа входжень: 2.

ПочинаєтьсяС

ПочинаєтьсяС(<Строка>, <СтрокаПоиска>) . Перевіряє чи починається рядок переданий у першому параметрі, з рядка у другому параметрі.

Приклад 20. Визначити чи починається ІПН обраного контрагента з цифри 1. Нехай у змінній Контрагент Контрагенти.

ІПН = Контрагент.ІПН; ПочинаєтьсяСединиці = СтрНачинаетсяС(ІПН, "1"); Якщо починаєтьсяСединиці Тоді //Ваш код КінецьЯкщо;

СтрЗакінчуєтьсяНа

СтрЗаканчиваетсяНа(<Строка>, <СтрокаПоиска>) . Перевіряє чи закінчується рядок переданий у першому параметрі, на рядок у другому параметрі.

Приклад 21. Визначити чи закінчується ІПН обраного контрагента на цифру 2. Нехай у змінній Контрагентзберігається посилання на елемент довідника Контрагенти.

ІПН = Контрагент.ІПН; Закінчується На Двійку = Стр Закінчується На (ІПН, "2"); Якщо закінчується на двійку тоді // Ваш код Кінець Якщо;

Поділити

Розділити(<Строка>, <Разделитель>, <ВключатьПустые>) . Розділяє рядок на частини за вказаними символами-розділювачами та записує отримані рядки у масив. У першому параметрі зберігається вихідний рядок, у другому рядок містить роздільник, у третьому вказується, чи потрібно записувати в масив порожні рядки (за замовчуванням Істина).

Приклад 22. Нехай у нас є рядок, який містить числа розділені символом «;», отримати з рядка масив чисел.

Рядок = "1; 2; 3"; Масив = РОЗДІЛИТИ(Рядок, ";"); Для Сч = 0 По Масив. Кількість () - 1 Цикл Спроба Масив [Сч] = Число (СокрЛП (Масив [Сч])); Виняток Масив [Сч] = 0; КінецьСпроби КінецьЦикл;

В результаті виконання буде отримано масив із числами від 1 до 3-х.

СтрЗ'єднати

СтрЗ'єднати(<Строки>, <Разделитель>) . Перетворює масив рядків з першого параметра на рядок, що містить всі елементи масиву через роздільник, зазначений у другому параметрі.

Приклад 23. Використовуючи масив чисел із попереднього прикладу, одержати вихідний рядок.

Для Сч = 0 По Масив. Кількість () - 1 Цикл Масив [Сч] = Рядок (Масив [Сч]); КінецьЦикл; Рядок = СтрЗ'єднати(Масив, "; ");

До базових можливостей мови програмування зазвичай відносять роботу з числами та рядками. Зазвичай, ці можливості зашиті в код компілятора (або реалізовані «базові» класи мови програмування).

У 1С можливості роботи з рядками запрограмовані у самій платформі. Сьогодні ми розглянемо особливості роботи з рядками 1С у програмах вбудованою мовою 1С.

Значення рядка 1С

1. Почнемо з найпростішого. Створення змінної та привласнення їй рядкового константного значення виглядає в 1С так:

Змінна = "Привіт, мир!";

Якщо потрібно в константному рядковому значенні 1С вказати символ лапки, його потрібно завдоїти «»

Змінна = "Привіт, "світ"!";

2. Перенесення рядка 1С можна вказати одразу двома способами. Перший – із використанням символу |

Змінна = "Привіт,
| мир! ";

Другий – із використанням системного перерахування Символи. Воно дозволяє додати перенесення рядка 1С, так і інші недруковані символи, наприклад TAB.

Змінна = "Привіт" + Символи. ПС + "світ!";

3. Конфігурації в 1С можуть бути розроблені не тільки для однієї мови (російської, англійської чи іншої) - але одночасно для кількох мов. У цьому випадку мова, що використовується в даний час, вибирається в нижній частині вікна 1С.

Список мов знаходиться у вікні конфігурації у гілці Загальні/Мови. Кожна мова має короткий ідентифікатор, такий як ruабо eng.

Зрозуміло, що при програмуванні такої конфігурації рядка 1С теж можуть бути багатомовними. Для цього є можливість створити такий рядок 1С, вказавши через; варіанти щодо ідентифікатора мови:

Змінна = "ru=""Привіт, мир!"; en=""Hello, world! """;

Якщо Ви використовуватимете сформований так рядок 1С як завжди – то він і буде тим, що в ньому написано. Для того, щоб система розбивала її на два варіанти та використовувала потрібний – необхідно використовувати функцію НСТ():

// Правильно для двомовних конфігурацій
Повідомити(НСтр(Змінна));

Реквізит із типом рядка 1С

Реквізит – це поле довідника/документу 1С. Відрізняється від змінної у програмі мовою 1С тим, що з реквізиту точно вказується його тип (число, рядок 1С тощо.). Якщо Вам потрібно освіжити в пам'яті, що таке реквізит – подивіться урок, присвячений .

Якщо Ви вкажете тип реквізиту – рядок 1С, додатково необхідно вказати параметри.

Рядки 1С бувають необмеженої довжини (вказується як довжина = 0) та обмеженої довжини, із зазначенням точної кількості символів. Рядки 1С необмеженої довжини зберігаються в окремій таблиці SQL, тому їх використання є менш продуктивним, ніж обмеженою.

Саме тому використання рядків 1С необмеженої довжини має свої обмеження – не скрізь їх можна використовувати. Наприклад, не можна як номер документа, код довідника, вимірювання.

Робота з рядками 1С

Для роботи з рядками є кілька вбудованих функцій платформи 1С.

  • СокрЛП("Неймовірно, але факт!")
    Забирає з рядка 1С зайві прогалини. Також можна використовувати перетворення будь-яких типів до рядку 1С (наприклад, числа).
  • Змінна = "Вася" + СокрЛП ("плюс") + "Оля"; //буде "Вася плюс Оля"
    Приклад підсумовування кількох рядкових значень 1С. В результаті вийде один рядок 1С.
  • Змінна = Лев ( "Музика", 2); //буде "Му"
    Змінна = Середовище ( "Музика", 2, 2); //буде "зи"
    Змінна = Прав("Музика", 2); //буде "ка"
    Різні варіанти отримання підрядка з рядка 1С.
  • Змінна = Знайти ( "Музика", "Зи"); //буде 3
    Пошук підрядки у рядку 1С, починаючи із символу 1.
  • Змінна = СтрДліна ("Музика"); //буде 6
    Повертає кількість символів у рядку 1С.
  • Повідомити("Привіт") //у вікні повідомлень внизу вікна 1С
    Попередження ("Привіт") // діалогове вікно, що спливає.
    Стан("Привіт") //У рядку відображення стану внизу зліва
    .

Приведення об'єктів до рядка 1С

Як відомо, найпопулярніший формат для обміну структурованою інформацією в даний час – це XML. Навіть остання версія MS Office Word та Excel зберігають файли у цьому форматі (docx та xlsx відповідно, поміняйте розширення на zip, відкрийте в архіваторі).

Платформа 1С обмінюватись даними надає кілька варіантів, основний у тому числі – також XML.

1. Найпростіший метод – використання функції СокрЛП() чи Рядка(). У тексті запиту можна використовувати функцію ПРЕДСТАВЛЕННЯ(). Результат їхньої дії той самий – вони генерують рядкове представлення будь-якого об'єкта 1С для користувача.

Для довідника за умовчанням це буде його найменування. Для документа – ім'я документа, номер та дата.

2. Будь-який об'єкт 1С (з обмеженнями) може бути перетворений на XML і назад. Процес перетворення називається серіалізація.

РядокВиглядXml = XMLРядок(Значення); //отримуємо XML зі значення 1С
Значення1С = XMLЗначення(Тип("ДовідникПосилання.Номенклатура"),РядокВидаXml); //отримуємо значення 1С з рядка XML, необхідно вказати тип 1С, який має бути отриманий

3. Існує власний спосіб платформи 1С перетворити на рядок будь-який об'єкт 1С. Він мігрував із версії 1С 7.7. Цей формат не розуміють інші програми, але розуміє інший 1С, що дозволяє легко використовувати його для обміну між базами 1С.

Рядок = ЗначенняВСрядокВнутр(Значення1С); //отримуємо рядок 1С значення 1С
ЗначенняФайл("C:\MyFile.txt", Значення1С); //інший варіант, отримуємо файл із збереженим рядком із значення 1С
Значення1С = ЗначенняІзрядуВнутрішньо(Рядок); //назад з рядка 1С
Значення1С = ЗначенняІзФайлу("C:\MyFile.txt"); //назад з файлу

Редагування рядків 1С на формі

Крім роботи з рядками 1С у програмі мовою 1С звичайно хотілося б, щоб користувач міг їх редагувати. Для цього є кілька можливостей:

1. Найпростіший спосіб – запросити введення рядка 1С на вимогу. Цей спосіб використовують при навчанні програмування 1С, у житті він застосовується набагато рідше (але застосовується!).

Змінна = "";
Рядок = ВвестиЗначення(Змінна, "Введіть ПІБ");

2. Для виведення реквізиту об'єкта 1С (довідника/документа) або реквізиту форми (див.) найчастіше використовують поле введення. Це найпоширеніший у 1С інструмент для роботи користувача з редагуванням полів.

3. Можливості поля введення можна розширити (див. властивості поля введення, правою кнопкою на ньому, докладніше):

  • Галочка Багаторядковий режим редагування
  • Галочка Розширене редагування (доступна, якщо встановлена ​​попередня галочка)
  • Галочка Режим пароля (див. ).

4. Якщо всіх можливостей поля введення Вам не вистачає, є вбудований редактор. Для додавання на форму потрібно в меню Форма/Вставити елемент керування додати Поле текстового документа. У його властивостях можна вказати режим роботи – властивість Розширення.

Поле текстового документа не можна безпосередньо пов'язати з даними. Необхідно в обробнику події Привідкритті() форми (див. ) прописати функцію:

ЕлементиФорми.ІмяЕлементуПолеТекстовогоДокумента.УстановитиТекст(ЗначенняРядок); //тут ЗначенняРядок - це текст отриманий, наприклад з реквізиту

А в обробника збереження – наприклад, у кнопці Зберегти – додати збереження:

ЗначенняРядок = ЕлементиФорми.ІмяЕлементуПолеТекстовогоДокументу.ОтриматиТекст(); //ЗначенняРядок тут - це реквізит, куди ми зберігаємо значення

5. У 1С версії 8.2.11 у керованих формах з'явилася нова можливість подання рядка 1С – поле Форматований документ.


Аналогічно поля текстового документа, необхідно встановлювати при відкритті і записувати при збереженні текст самостійно за допомогою програми.

  • До об'єкта 1С, форму якого ми робимо (довідник, документ, обробка тощо) – додайте реквізит із типом СховищеЗначення
  • У функції Причитанні на сервері () встановимо текст з реквізиту

    //Тут Реквізит - це доданий реквізит об'єкта 1С
    //тут ФорматованийДокумент – це ім'я поля на формі для редагування
    &На сервері

    ФорматованийДокумент = ПоточнийОб'єкт.Реквізит.Отримати();
    КінецьПроцедури

  • У функції ПередЗаписомНа Сервері() або по кнопці запишемо текст з поля

    &На сервері
    Процедура при читанні на сервері (Поточний об'єкт)
    ПоточнийОб'єкт.Реквізит = Новий СховищеЗначення(ФорматованийДокумент);
    КінецьПроцедури

Механізмів для роботи з рядками у запитах 1С мало. По-перше, рядки можна складати. По-друге, від рядка можна взяти підрядок. По-третє, рядки можна порівнювати, зокрема за шаблоном. Ось мабуть і все, що можна робити з рядками.

Складання рядків

Для додавання рядків у запиті використовується операція «+». Складати можна лише рядки обмеженої довжини.

ВИБРАТИ "Найменування: " + Контрагенти.Найменування ЯК Колонка1 З Довідник.Контрагенти ЯК Контрагенти ДЕ Контрагенти.Посилання = &Посилання

Функція Підстроювання

ПІДСТРОКУ(<Строка>, <НачальнаяПозиция>, <Длина>)

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

Якщо довжина рядка менша, ніж зазначено у другому параметрі, то функція поверне порожній рядок.

Увага!Використання функції ПІДСТРОКУ() з метою приведення рядків необмеженої довжини до рядків обмеженої довжини не рекомендується. Замість неї краще використовувати операцію наведення типу ВИРАЗИТИ().

Функція Подібно

Якщо потрібно переконатися, що рядковий реквізит відповідає певним критеріям, ми його порівнюємо:

ВИБРАТИ Контрагенти.Найменування ЯК Колонка1 З Довідник.Контрагенти ЯК Контрагенти ДЕ Контрагенти.Найменування = "Газпром"

А що, коли потрібно хитріше порівняння? Не просто на рівність чи нерівність, а на подібність до певного шаблону? Ось саме для цього і створена функція подібно.

ПОДІБНО — Оператор перевірки рядка на зразок шаблону. Аналог LIKE у SQL.

Оператор подібно дозволяє порівняти значення виразу, вказаного зліва від нього, з рядком шаблону, вказаним праворуч. Значення виразу має мати рядок. Якщо значення виразу задовольняє шаблон - результатом оператора буде ІСТИНА, інакше - БРЕХНЯ.

Наступні символи у рядку шаблону є службовими і мають сенс, відмінний від символу рядка:

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

Будь-який інший символ означає сам себе і не несе жодного додаткового навантаження. Якщо як самого себе необхідно записати один із перелічених символів, то йому має передувати<Спецсимвол>. Сам<Спецсимвол>(будь-який відповідний символ) визначається в цьому ж операторі після ключового слова СПЕЦСИМВОЛ.

Тип "Рядок" зустрічається у всіх мовах програмування. Він є примітивним, і у 1С існує багато функцій для роботи з ним. У цій статті ми докладно розглянемо різні способи роботи з рядковими типами 1С 8.3 та 8.2 на прикладах.

Рядок

Для того, щоб перетворити змінну будь-якого типу на рядок, існує однойменна функція «Рядок()». Вхідним параметром буде сама змінна, рядкове представлення якої потрібно отримати.

Рядок (Брехня) // Повертає «Ні»
Рядок(12345) // повертає «12 345»
Рядок(ПоточнаДата()) //»21.07.2017 11:55:36″

Перетворювати до рядка можна як примітивні типи, а й інші, наприклад елементи довідників, документів.

СокрЛП, СокрЛ, СокрП

Як вхідні параметри даних функцій виступає змінна рядкового типу. Функції видаляють незначні символи (пробіли, переноси каретки та інші): з лівого та правого боку, тільки з лівого боку, і лише з правого відповідно.

СокрЛП("Будуть видалені пробіли з обох сторін") // "Будуть видалені пробіли з обох сторін"
СокрЛ("Будуть видалені пробіли з обох сторін") // "Будуть видалені пробіли зліва"
СокрП("Будуть видалені пробіли з обох сторін") // "Будуть видалені пробіли праворуч"

Лев, Правий, Середовище

Ці функції дозволяють обрізати частину рядка. Функція «Лев()» поверне частину рядка з лівого боку зазначеної довжини. Функція «Прав()» аналогічна, але обрізка проводиться праворуч. Функція «Серед()» дозволяє вказати номер символу, з якого буде виділено рядок та його довжину.

Лев («Строкова змінна», 4) // Повертає «Стро»
Прав(«Строкова змінна», 7) // повертає «ременна»
Середовище («Строкова змінна», 2, 5)// повертає «троко»

СтрДліна

Функція визначає кількість символів, які містяться у рядковій змінній.

СтрДліна («Слово») // Результатом виконання буде число 5

Знайти

Функція дає можливість шукати в будь-якій рядковій змінній частині рядка. Як значення, що повертається буде виступати число, яке показує позицію початку знайденого рядка. Якщо збігів не виявлено, нуль повертається.

Зверніть увагу, що пошук здійснюється з урахуванням регістру. Якщо в початковому рядку буде більше одного входження підрядка пошуку, функція поверне початок першого входження.

Знайти («раз, два, раз, два, три», «два») // Функція поверне число 6

Порожня стрічка

Використання цієї функції дозволяє визначити, чи є рядок порожнім. Незначні символи, наприклад, пробіл, перенесення каретки та інші не враховуються.

ПорожнійРядок («Пупкін Василь Іванович») // функція поверне значення Брехня
ПорожнійРядок() «) // функція поверне значення Істина

ВРег, НРег, трег

Дані функції дуже корисні при порівнянні та перетворенні рядкових змінних. «Врег()» поверне вихідний рядок у верхньому регістрі, «НРег()» у нижньому, а «Трєг()» відформатує його так, що перший символ кожного окремого слова буде з великої літери, а всі наступні з маленької.

ВРег(«ГеНЕРАЛЬНИЙ ДИРЕКТОР») // значення, що повертається – «ГЕНЕРАЛЬНИЙ ДИРЕКТОР»
НРег(«ГеНераЛьний дИРЕктОр») // значення, що повертається – «генеральний директор»
ТРег («ГеНераЛьНий дІрЕКтор») // значення, що повертається – «Генеральний Директор»

СтрЗамінити

Ця функція є аналогом заміни текстових редакторах. Вона дозволяє підміняти один символ або набір символів іншим у рядкових змінних.

СтрЗаменить(«червоний, білий, жовтий», «,», «;») // поверне «червоний; білий; жовтий»

СтрЧислоРядок

Функція дозволяє визначити кількість рядків, розділених перенесенням каретки в текстовій змінній.

Цикл, у наведеному нижче прикладі, пройде три кола, оскільки функція СтрЧислоРок поверне значення 3:

Для інд=1 по СтрЧислоРядок («Рядок1» + Символи.ПС + «Рядок2» + Символи.ПС + «Рядок3») Цикл
<тело цикла>
КінецьЦикл;

СтрОтриматиРядок

Ця функція працює з багаторядковим текстом так само, як і попередня. Вона дозволяє отримати певний рядок із текстової змінної.

СтрОтриматиСтроку(«Рядок1» + Символи.ПС + «Рядок2» + Символи.ПС + «Рядок3», 2) // поверне «Рядок2»

СтрЧіслоВходжень

Функція підраховує кількість входжень символу або підрядки в рядку.

СтрЧислоВкладень(«а;б;в;г;«,«;») // функція поверне число 4

Символ та КодСимволу

Ці функції дозволяють отримувати символ за кодом кодування Unicode, а також визначати цей код за самим символом.

КодСимволу(«А») // функція поверне число 1040
Код Символу (1040) // Функція поверне «А»

Часті завдання під час роботи з рядками

Об'єднання рядків

Щоб об'єднати кілька рядків (здійснити конкатенацію), достатньо використовувати оператор додавання.

"Рядок 1" + "Рядок 2" //результатом складання двох рядків буде "Рядок 1 Рядок 2"

Перетворення типів

Для того, щоб перетворити тип на рядок, наприклад, посилання на елемент довідника, число та інше, достатньо використовувати функцію «Рядок()». Функції, подібні до «СокрЛП()» так само перетворюватимуть змінні в рядок, але вже відразу з відсіканням незначних символів.

Рядок (1000) // поверне «1 000»

Зверніть увагу, що при перетворенні числа в рядок, програма автоматично додала пробіл, що відокремлює тисячу. Для того, щоб цього уникнути, можна скористатися такими конструкціями:

СтрЗаменить(Рядок(1000),Символи.НПП,»») // поверне «1000»

Рядок (Формат (1000, "ЧГ =")) // поверне "1000"

Лапки у рядку

Досить часто вам доведеться стикатися з необхідністю вказати у рядковій змінній лапки. Це може бути текст запиту, написаний в конфігураторі, так і просто змінна. Для вирішення цієї задачі вам достатньо встановити два символи лапок.

Заголовок = Рядок («ТОВ ««Роги та копита»» - це ми!») // поверне «ТОВ «Роги та копита» - це ми!»

Багаторядність, перенесення рядка

Для того, щоб створити багаторядковий текст, достатньо додати до нього символи перенесення рядка (Символи.ПС).

Багаторядковий Текст = «Перший рядок» + Символи.ПС + «Другий рядок»

Як прибрати прогалини

Для того, щоб прибрати прогалини праворуч або ліворуч, можна скористатися функцією «СокрЛП()» (а також «СокрЛ()» і «СокрЛ()»):

РядокБезпробілів = СокрЛП("Багато букв") // функція поверне значення "Багато букв"

Якщо після перетворення числа в рядок вам потрібно було прибрати нерозривні прогалини, скористайтеся наступною конструкцією:

РядокБезпробілів = СтрЗаменить(Рядок(99999),Символи.НПП,»») // поверне «99999»

Також програмісти часто користуються нижче наведеною конструкцією, яка дозволяє видалити, або замінити на інший символ усі прогалини текстової змінної:

РядокБезпробілів = Стр Замінити («прийом», », »») // поверне «привіт»

Порівняння рядків між собою

Порівняти терміни можна звичайним знаком рівності. При порівнянні враховується регістр.

«Здрастуйте» = «здравствуйте» // поверне Брехня
«Здрастуйте» = «Здрастуйте» // поверне Істина
«Здрастуйте» = «До побачення» // поверне Брехня

Поділитися