Метод 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    5338    DeerCven    15    

57

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

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

21.05.2024    46119    dimanich70    83    

163

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

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

1 стартмани

18.03.2024    6820    6    John_d    13    

59

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

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

12.02.2024    57067    atdonya    31    

68

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

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

30.11.2023    8577    ke.92@mail.ru    17    

67

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

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

28.08.2023    22696    YA_418728146    8    

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