Контакти

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

Реалізовано у версії 8.3.6.1977.

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

Усі дії, які виконують нові функції, ви могли виконувати раніше. За допомогою більш-менш складних алгоритмів, написані вбудованою мовою. Тому нові функції не дають вам якихось нових можливостей. Однак вони дозволяють скоротити кількість коду, зробити код більш простим та зрозумілим. А крім цього, вони дозволяють прискорити виконання дій. Тому що функції, реалізовані в платформі, працюють, звичайно ж, швидше, ніж аналогічний алгоритм, написаний вбудованою мовою.

Функція форматування СтрШаблон()

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

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

<Шаблон>- це рядок, у якому потрібно підставити уявлення параметрів.

<Значение1> , ... <Значение10>- це параметри (максимально – десять), уявлення яких потрібно підставити у рядок.

Щоб вказати конкретне місце у шаблоні, в якому потрібно виконати підстановку, потрібно використовувати маркер виду %1, ... %10. Кількість маркерів, задіяних у шаблоні, та кількість параметрів, що містять значення, мають збігатися.

Наприклад, результатом виконання такого оператора:

буде рядок:

Помилка даних у рядку 2 (потрібен тип Дата)

Функція роботи з рядками СтрПорівняти()

Ця функція порівнює два рядки без урахування регістру. Наприклад, так:

Цю ж дію ви могли виконати і раніше за допомогою об'єкта ПорівнянняЗначень:

Однак, використання нової функції виглядає більш простим. Крім цього функція, на відміну від об'єкта ПорівнянняЗначень, працює і в тонкому клієнті, і в веб-клієнті.

Функції роботи з рядками СтрНачинаетсяС(), СтрЗаканчиваетсяНа()

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

Наприклад, їх зручно використовувати в операторі Якщо:

Функції роботи з рядками СтрРозділити()

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

Функція роботи з рядками СтрНайти()

Замість старої функції Знайти() ми реалізували нову функцію, яка має додаткові можливості:

  • Пошук у різних напрямках (з початку, з кінця);
  • Пошук із зазначеної позиції;
  • Пошук входження із зазначеним номером (друге, третє тощо).

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

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

Рядки 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С:Підприємство 8. Змінні з типом рядокмістять текст.

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

Пер1 = "Слово 1";
Пер2 = "Слово 2";
Пер3 = Пер1 + "" + Пер2;

В підсумку Пер3матиме значення « Слово 1 Слово 2”.

Крім того, в системах 1С:Підприємство 8 передбачені функції для роботи з рядками. Розглянемо основні:

ВвестиРядок(<Строка>, <Подсказка>, <Длина>, <Многострочность>) — функція призначена для виведення діалогового вікна, в якому користувач може вказати значення змінної типу Рядок. Параметр <Строка> є обов'язковим і містить ім'я змінної, в яку буде записано введений рядок. Параметр <Подсказка> необов'язковий це заголовок діалогового вікна. Параметр <Длина> необов'язковий, показує максимальну довжинурядка, що вводиться. За замовчуванням дорівнює нулю, що означає необмежену довжину. Параметр <Многострочность> необов'язковий. Визначає режим введення багаторядкового тексту: Істина – введення багаторядкового тексту з роздільниками рядків; Брехня - введення простого рядка.

Рядок можна ввести і, знаючи код символу в кодуванні Unicode:

Символ(<КодСимвола>) — код вводиться як числа.

Літера = Символ (1103); // Я

Існує і зворотна функція, що дозволяє дізнатися код символу.

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

Функції перетворення регістру тексту:

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

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

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

Функції пошуку та заміни символів у рядку:

Знайти (<Строка>, <ПодстрокаПоиска>) - знаходить номер символу входження підрядка пошуку. Наприклад:

Знайти ("Рядок", "ока"); // 4

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

Номер4 Входження = СтрНайти ( "Обороноспроможність", "О" , Напрям Пошуку. Спочатку, 1, 4); // 7

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

СтрЗамінити ("Рядок", "ока", ""); // Стор

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

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

СтрЧислоВходжень ( "вчитися, вчитися та ще раз вчитися", "вчитися", ""); // 3

СтрШаблон(<Строка>, <ЗначениеПодстановки1>…<ЗначениеПодстановкиN> — підставляє параметри у рядок за номером. Рядок повинен містити маркер підстановки виду: «%1..%N». Нумерація маркерів починається з 1. Якщо значення параметра Не визначене, підставляється порожній рядок.

СтрШаблон ( "Параметр 1 = %1, Параметр 2 = %2", "1" , "2" ) ; // Параметр 1 = 1, Параметр 2 = 2

Функції перетворення рядків:

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

Прав(<Строка>, <ЧислоСимволов>) - Повертає останні символи рядка.

Середа(<Строка>, <НачальныйНомер>, <ЧислоСимволов>) - Повертає рядок довжиною в<ЧислоСимволов>, починаючи з символу<НачальныйНомер>.

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

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

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

СтрОтриматиРоку(<Строка>, <НомерСтроки>) – отримує рядок рядкового рядка за номером.

Інші функції:

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

СтрЧислоРядок(<Строка>) – повертає число рядків у рядковому рядку. Рядок вважається новим, якщо він відокремлений від попереднього символом перекладу рядка.

Стр Порівняти(<Строка1>, <Строка2> ) – порівнює два рядки без урахування регістру. Функція працює аналогічно об'єкту ПорівнянняЗначень. Повертає:

  • 1 — якщо перший рядок більший за другий
  • -1 — якщо другий рядок більший за перший
  • 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С
    //тут ФорматованийДокумент – це ім'я поля на формі для редагування
    &На сервері

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

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

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



Сподобалась стаття? Поділіться їй