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

18.09.24

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

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

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

Задача:

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

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

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

 

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

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

	Возврат ТЗ;

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

Вступайте в нашу телеграмм-группу Инфостарт

Excel

См. также

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

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

14.05.2025    3481    DeerCven    8    

46

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

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

21.05.2024    41106    dimanich70    83    

157

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

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

1 стартмани

18.03.2024    6039    6    John_d    11    

58

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

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

12.02.2024    49345    atdonya    30    

66

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

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

30.11.2023    7808    ke.92@mail.ru    17    

66

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

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

28.08.2023    21043    YA_418728146    8    

174
Для отправки сообщения требуется регистрация/авторизация