1С 8.3 Таблица значений с колонкой любого имени (без ограничений используемых символов)
Данные > Примеры кода 1С > 1С 8.3 Таблица значений
Перейти в раздел примеры кода 1С 8.3:
Таблица значений с колонкой любого имени (без ограничений используемых символов) в 1С 8.3:
// Возвращает новую таблицу значений с добавлением новой колонки в обход ограничений доступных символов в имени.
// Использовать не рекомендуется. Просто забавы ради.
// Источник: https://github.com/SeiOkami/CollectionMethodsOneS/issues/35
//
// Параметры:
// ПлохоеИмя - Строка - Имя добавляемой колонки, которое может не соответствовать требованиям к символам
// ИсходнаяТаблица - Неопределено, ТаблицаЗначений - Функция вернет новую ТЗ на основе переданной
// ОписаниеТипа - ОписаниеТипов, Неопределено - Описание типа добавляемой колонки
// Заголовок - Строка - Заголовок добавляемой колонки
//
// Возвращаемое значение:
// ТаблицаЗначений - новая таблица значений с добавленной колонкой
//
// Пример:
// ТЗ = ТаблицаЗначенийСПлохойКолонкой("12345");
// ТЗ = ТаблицаЗначенийСПлохойКолонкой(" --23-502 =-2-=6524-0624 ", ТЗ);
Функция ТаблицаЗначенийСПлохойКолонкой(Знач ПлохоеИмя, Знач ИсходнаяТаблица = Неопределено,
Знач ОписаниеТипа = Неопределено, Знач Заголовок = "") Экспорт
ТаблицаЗначений = ?(ИсходнаяТаблица = Неопределено,
Новый ТаблицаЗначений, ИсходнаяТаблица);
ВременноеИмя = "_" + СтрЗаменить(Строка(Новый УникальныйИдентификатор), "-", "");
ТаблицаЗначений.Колонки.Добавить(ВременноеИмя, ОписаниеТипа, Заголовок);
СтрокаВнутр = ЗначениеВСтрокуВнутр(ТаблицаЗначений);
СтрокаВнутр = СтрЗаменить(СтрокаВнутр, ВременноеИмя, ПлохоеИмя);
ИсходнаяТаблица = ЗначениеИзСтрокиВнутр(СтрокаВнутр); // ТаблицаЗначений
Возврат ИсходнаяТаблица; //@skip-check constructor-function-return-section - Баг ЕДТ - не понимает типизированный коммент
КонецФункции
// MIT License
// Copyright (c) 2024 SeiOkami
//
// Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files
// (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify,
// merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is
// furnished to do so, subject to the following conditions:
// The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software.
// Использовать не рекомендуется. Просто забавы ради.
// Источник: https://github.com/SeiOkami/CollectionMethodsOneS/issues/35
//
// Параметры:
// ПлохоеИмя - Строка - Имя добавляемой колонки, которое может не соответствовать требованиям к символам
// ИсходнаяТаблица - Неопределено, ТаблицаЗначений - Функция вернет новую ТЗ на основе переданной
// ОписаниеТипа - ОписаниеТипов, Неопределено - Описание типа добавляемой колонки
// Заголовок - Строка - Заголовок добавляемой колонки
//
// Возвращаемое значение:
// ТаблицаЗначений - новая таблица значений с добавленной колонкой
//
// Пример:
// ТЗ = ТаблицаЗначенийСПлохойКолонкой("12345");
// ТЗ = ТаблицаЗначенийСПлохойКолонкой(" --23-502 =-2-=6524-0624 ", ТЗ);
Функция ТаблицаЗначенийСПлохойКолонкой(Знач ПлохоеИмя, Знач ИсходнаяТаблица = Неопределено,
Знач ОписаниеТипа = Неопределено, Знач Заголовок = "") Экспорт
ТаблицаЗначений = ?(ИсходнаяТаблица = Неопределено,
Новый ТаблицаЗначений, ИсходнаяТаблица);
ВременноеИмя = "_" + СтрЗаменить(Строка(Новый УникальныйИдентификатор), "-", "");
ТаблицаЗначений.Колонки.Добавить(ВременноеИмя, ОписаниеТипа, Заголовок);
СтрокаВнутр = ЗначениеВСтрокуВнутр(ТаблицаЗначений);
СтрокаВнутр = СтрЗаменить(СтрокаВнутр, ВременноеИмя, ПлохоеИмя);
ИсходнаяТаблица = ЗначениеИзСтрокиВнутр(СтрокаВнутр); // ТаблицаЗначений
Возврат ИсходнаяТаблица; //@skip-check constructor-function-return-section - Баг ЕДТ - не понимает типизированный коммент
КонецФункции
// MIT License
// Copyright (c) 2024 SeiOkami
//
// Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files
// (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify,
// merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is
// furnished to do so, subject to the following conditions:
// The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software.
0
комментарии
____________________
Перепечатка текста и фотографий разрешена при наличии прямой ссылки на источник