Метод Merge Pandas для 1С при работе с файлом Excel

18.09.24

Разработка - Универсальные функции

Использование merge Pandas в среде 1С при работе с многостраничным файлом Excel.

Методом Merge Pandas можно соединять несколько таблиц в одну, не написав многостраничный код. В среде 1С для типа ТаблицаЗначений нет типового метода.

Задача:

  • Есть Файл Excel с несколькими листами названия которых нам неизвестны;
  • Колонки в некоторых листах больше, знаем что названия совпадают, но некоторые колонки отсутствуют на других листах
  • Объединить листы в одну таблицу для дальнейшей работы с данными на платформе 1С

Зная метод Merge Pandas решил реализовать аналогичное решение на базе 1С.

Функция реализации на &Сервере:

 

	ТабДок = Новый ТабличныйДокумент;
	Попытка
		ТабДок.Прочитать(ФайлЗагрузки, СпособЧтенияЗначенийТабличногоДокумента.Текст);
	Исключение
		Сообщение = Новый СообщениеПользователю;
		Сообщение.Текст = ОписаниеОшибки();
		Сообщение.Сообщить();
	КонецПопытки; 
	
	ТЗ = Новый ТаблицаЗначений;

	Для Каждого Область Из ТабДок.Области Цикл
		
		ПостроительЗапроса = Новый ПостроительЗапроса;
		ПостроительЗапроса.ИсточникДанных = Новый ОписаниеИсточникаДанных(ТабДок.Область(Область.Имя));
		ПостроительЗапроса.ДобавлениеПредставлений = ТипДобавленияПредставлений.НеДобавлять;
		ПостроительЗапроса.ЗаполнитьНастройки();
		ПостроительЗапроса.Выполнить();
		
		ТаблицаДанных = ПостроительЗапроса.Результат.Выгрузить();
		
		Для каждого Колонка Из ТаблицаДанных.Колонки Цикл
			
			ЕстьКолонка = ТЗ.Колонки.Найти(Колонка.Имя);
			
			Если ЕстьКолонка = Неопределено Тогда
				ТЗ.Колонки.Добавить(Колонка.Имя);	
			КонецЕсли;
			
		КонецЦикла;
		
		Для каждого Строка Из ТаблицаДанных Цикл
			ЗаполнитьЗначенияСвойств(ТЗ.Добавить(), Строка)
		КонецЦикла;
	КонецЦикла;

	Возврат ТЗ;

Мы уже прочитали ФайлЗагрузки, отправили его на сервер, а в Функции уже работаем с ТабличнымДокументом и читаем данные с каждого листа, соединяем в одну ТаблицуЗначений. На выходе возвращаем общую ТаблицуЗначений для дальнейшей работы.

Excel

См. также

Универсальные функции Программист Платформа 1С v8.3 Конфигурации 1cv8 Бесплатно (free)

Благодаря этим пяти строчкам можно больше не заморачиваться с загрузкой из внешних файлов. Пользуюсь везде, всегда и постоянно.

21.05.2024    20094    dimanich70    81    

144

Универсальные функции Программист Платформа 1С v8.3 Конфигурации 1cv8 Абонемент ($m)

Задача: вставить картинку из буфера обмена на форму средствами платформы 1С.

1 стартмани

18.03.2024    4089    3    John_d    11    

57

Универсальные функции Программист Стажер Платформа 1С v8.3 Конфигурации 1cv8 Бесплатно (free)

Пришлось помучиться с GUID-ами немного, решил поделиться опытом, мало ли кому пригодится.

12.02.2024    18028    atdonya    24    

56

Универсальные функции Программист Платформа 1С v8.3 Бесплатно (free)

На заключительных этапах, когда идет отладка или доработка интерфейса, необходимо много раз переоткрыть внешний объект. Вот один из способов автоматизации этого.

30.11.2023    5500    ke.92@mail.ru    16    

65

WEB-интеграция Универсальные функции Механизмы платформы 1С Программист Платформа 1С v8.3 Конфигурации 1cv8 Бесплатно (free)

При работе с интеграциями рано или поздно придется столкнуться с получением JSON файлов. И, конечно же, жизнь заставит проверять файлы перед тем, как записывать данные в БД.

28.08.2023    14723    YA_418728146    7    

166

Пакетная печать Печатные формы Адаптация типовых решений Универсальные функции Платформа 1С v8.3 1С:ERP Управление предприятием 2 1С:Управление торговлей 11 1С:Комплексная автоматизация 2.х Россия Абонемент ($m)

Расширение для программ 1С:Управление торговлей, 1С:Комплексная автоматизация, 1С:ERP, которое позволяет распечатывать печатные формы для непроведенных документов. Можно настроить, каким пользователям, какие конкретные формы документов разрешено печатать без проведения документа.

2 стартмани

22.08.2023    3573    56    progmaster    8    

4

Инструментарий разработчика Универсальные функции Платформа 1С v8.3 Конфигурации 1cv8 1С:Розница 2 1С:ERP Управление предприятием 2 1С:Бухгалтерия 3.0 1С:Управление торговлей 11 1С:Комплексная автоматизация 2.х 1С:Зарплата и Управление Персоналом 3.x Абонемент ($m)

Копирует в буфер значения из списков, из ячеек отчетов, таблиц, настроек списков, других отборов и вставляет в выбранную настройку отбора. Работает с Объект не найден. Работает как в одной так и между разными базами 1С. Использует комбинации [Alt+C] Копировать список, [Alt+V] Вставить список. Также для копирования данных используется стандартная [Ctrl+C] (например из открытого xls, mxl, doc и т.п. файла скопировать список наименований)

1 стартмани

13.10.2022    18474    171    sapervodichka    112    

135
Оставьте свое сообщение