1с знайти друге входження до рядка. Нові функції роботи з рядками

💖 Подобається?Поділися з друзями посиланням

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

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

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

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

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

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

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

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

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

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

буде рядок:

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

Всім привіт
Сьогодні попросили мене під час друку документа реалізації не виводити префікс документа, завдання вирішив так.

СтрЗаменить(Номер, Лев (Номер, 3), "");

Коли заглянув у синтакс-помічник, то мені це сподобалося, що захотілося написати про роботі з рядками у «1С:Підприємство».

Рядок у 1С відноситься до примітивного типу даних.

Якщо подивитися у довідку 1С побачимо наступний опис типу Рядок (String)
Значення даного типумістять рядок у форматі Unicode довільної довжини.
Якщо своїми словами про рядки, то вийде. Рядок - константа, що складається з різних символів, завжди обрамляється лапками.

Завдання рядка
Звернення = "Привіт пасажир";

Багаторядкові рядки у типових конфігураціях найчастіше створюються за допомогою вертикального роздільника «|»:
Рядок = «Многорядкова
|рядок
|пиши
|текст»;

Лапка всередині рядка задаються подвійними лапками.
Рядок = «Текст у лапках»;

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

Функцій по роботі з рядками

Тут у короткій формі наведу функцій роботи з рядками:

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

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

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

Знайти (<Строка>, <ПодстрокаПоиска>) — Функція знаходить входження шуканого рядка як підрядки у вихідному рядку.

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

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

ПорожнійРядок(<Строка>) — Функція перевіряє рядок на наявність символів.

Символ(<КодСимвола>) — Функція перетворює код символу на рядок, який містить символ.

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

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

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

Середовище<Строка>, <НачальныйНомер>, <ЧислоСимволов>) — Функція вибирає рядок символів, починаючи із символу<НачальныйНомер>, загальною кількістю<ЧислоСимволов>.

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

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

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

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

СтрЧислоРядок(<Строка>) — Функція вважає число рядків у рядковому рядку. У рядковому рядку рядки розділені символами перекладу рядків.

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

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

РядокІзЧисел = Рядок(Число);

Всі ці функції докладно описані в Синтакс-помічник, як програміст-початківець може допомогти Синтакс-помічник, я описав у статті .

Приклади роботи з рядками

Перетворення числа на рядок і назад.

Для отримання строкового подання року слід використовувати опцію Формат.

Рік = Формат(ПоточнаДата(), "ДФ=yyyy") // Рік = "2012"

Щоб перетворити число до рядка без вставки символу-розділювача груп ( нерозривної прогалини), необхідно застосувати функцію Формат із параметром ЧГ=0:

Число = 2012 Рядок = Формат (Число, "ЧГ = 0"); //Рядок = "2012"

Рядок Без пробілів.

Нотатки із Задзеркалля

18.08.2014 Нові функції роботи з рядками

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

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

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

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

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

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

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

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

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

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

буде рядок:

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

У 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С
    //тут ФорматованийДокумент – це ім'я поля на формі для редагування
    &На Сервері

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

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

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

Розповісти друзям