Универсальная загрузка файла *.CSV в ТЗ типовым решением (8.3.6+)

11.02.17

Интеграция - Внешние источники данных

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

Файлы

ВНИМАНИЕ: Файлы из Базы знаний - это исходный код разработки. Это примеры решения задач, шаблоны, заготовки, "строительные материалы" для учетной системы. Файлы ориентированы на специалистов 1С, которые могут разобраться в коде и оптимизировать программу для запуска в базе данных. Гарантии работоспособности нет. Возврата нет. Технической поддержки нет.

Наименование Скачано Купить файл
(только для физ. лиц)
Загрузка CSV в ТЗ.epf
.epf 12,48Kb
12 1 850 руб. Купить

Подписка PRO — скачивайте любые файлы со скидкой до 85% из Базы знаний

Оформите подписку на компанию для решения рабочих задач

Оформить подписку и скачать решение со скидкой

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

Простая функция чтения файла CSV и запись результата в ТЗ, да она медленея чем загрузка средствами ADO примерно 30%, но при прямых руках дает более качественный результат.

Функция ЗагрузитьИзФайлаCSV(ПутьКФайлу, ФайлCSV, Разделитель = ";", ОграничительСтроки = "", КодировкаФайла = "" , НачСтрока = 1, ЗагрузитьСтрок = 0, КоличествоКолонок = 10,ТабличныйДокумент = Неопределено) Экспорт
	
	Если ТабличныйДокумент = Неопределено Тогда ТабличныйДокумент = Новый ТекстовыйДокумент; КонецЕсли;
		
	Попытка
		ТабличныйДокумент.Прочитать(ПутьКФайлу+ФайлCSV, ?(КодировкаФайла = "",КодировкаТекста.ANSI,КодировкаФайла));  
	Исключение
		Сообщить(ОписаниеОшибки(), СтатусСообщения.Внимание);
		Возврат Новый ТаблицаЗначений;
	КонецПопытки;
	
	КолвоСтрокФайла = ТабличныйДокумент.КоличествоСтрок();
	КонечнаяКолонка = КоличествоКолонок;   
	
	Если КолвоСтрокФайла = 0 Тогда ТабличныйДокумент = Неопределено; Возврат Новый ТаблицаЗначений;   КонецЕсли;
	
	Если НачСтрока > КолвоСтрокФайла Тогда ТабличныйДокумент = Неопределено;  Возврат Новый ТаблицаЗначений;  КонецЕсли;
			
	ТабЗн=Новый ТаблицаЗначений;
	ТипЯчейки  =  Новый ОписаниеТипов("Строка",,Новый КвалификаторыСтроки(128));
	
	Для ит = 1 ПО КонечнаяКолонка Цикл
	   ТабЗн.Колонки.Добавить("F" + ит, ТипЯчейки);
	КонецЦикла;
	
	КонСтрока = НачСтрока + ЗагрузитьСтрок;
	КонСтрока = ?(КонСтрока = 1, КолвоСтрокФайла, КонСтрока);	
	 
	Для нСтрока = НачСтрока ПО КонСтрока Цикл
		Если нСтрока > КолвоСтрокФайла Тогда Прервать; КонецЕсли;
	    НоваяСтрокаТФ = ТабЗн.Добавить();
		СтрокаДокумента=СтрЗаменить(ТабличныйДокумент.ПолучитьСтроку(нСтрока),ОграничительСтроки+?(Разделитель="Таб",Символы.Таб,Разделитель),";");
		ЗначениеСтроки = СтрРазделить(СтрокаДокумента,";");
		КоличествоПозиций = ЗначениеСтроки.Количество();
		Для нКолонка=1 ПО ?(КоличествоПозиций<КонечнаяКолонка,КоличествоПозиций,КонечнаяКолонка) Цикл
	        НоваяСтрокаТФ["F" + нКолонка] = СтрЗаменить(ЗначениеСтроки[нКолонка-1],ОграничительСтроки,"");  
	    КонецЦикла;
	КонецЦикла;
	
	Возврат ТабЗн;
    
КонецФункции


Пример использования приведен в обработке.

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

CSV парсинг

См. также

Розничная торговля Внешние источники данных Файловый обмен (TXT, XML, DBF), FTP Системный администратор Программист Бухгалтерский учет 1С:Бухгалтерия 3.0 Фармацевтика, аптеки Россия Бухгалтерский учет Платные (руб)

Внешняя обработка загрузки данных из файла-выгрузки, сформированного в программе F3 TAIL версии 3.4 (и выше) или еФарма версии 2.1, в базу конфигурации 1С: Бухгалтерия предприятия 8, ред. 3.0 (базовая, ПРОФ, КОРП, ФРЕШ).

13200 руб.

19.12.2016    49626    101    106    

74

Производство готовой продукции (работ, услуг) Внешние источники данных 1С v8.3 1С:Управление нашей фирмой 1.6 Лесное и деревообрабатывающее хозяйство Россия Управленческий учет Платные (руб)

Обработка предназначена для загрузки файлов, выгруженных из системы Базис-мебельщик, в справочник 1С "Спецификации" для последующих процессов учета и диспетчирования полуфабрикатов и изделий.

10200 руб.

24.06.2021    22750    58    55    

40

Внешние источники данных Программист Бизнес-аналитик Пользователь 1С v8.3 Управляемые формы Анализ и прогнозирование 1C:Бухгалтерия Узбекистан Беларусь Кыргызстан Молдова Россия Казахстан Платные (руб)

Готовое решение для автоматической выгрузки данных из 1С 8.3 в базу данных ClickHouse, PostgreSQL или Microsoft SQL для работы с данными 1С в BI-системах. «Экстрактор данных 1С в BI» работает со всеми типовыми и нестандартными конфигурациями 1С 8.3 и упрощает работу бизнес-аналитиков. Благодаря этому решению, специалистам не требуется быть программистами, чтобы легко получать данные из 1С в вашей BI-системе.

28500 руб.

15.11.2022    25081    27    49    

42

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

Быстро и легко. Выгрузка всех элементов и групп номенклатуры (с их иерархией), кроме помеченных на удаление. Без использования COM-объектов.

4800 руб.

16.08.2023    2277    6    8    

9

Внешние источники данных Банковские операции Бухгалтер 1С v8.3 Бухгалтерский учет 1С:Бухгалтерия государственного учреждения Россия Бухгалтерский учет Платные (руб)

Обработки для загрузки данных из УРМ "Криста" в бухгалтерию государственного учреждения редакция 2.0. Есть Демо доступ на вкладке Бесплатные файлы на 1 месяц со дня получения демонстрационного ключа регистрации. Поддерживает ПО "Web-исполнение" от НПО "Криста".

4800 руб.

19.06.2013    40593    143    108    

36
Комментарии
Подписаться на ответы Инфостарт бот Сортировка: Древо развёрнутое
Свернуть все
1. etmarket 937 13.02.17 08:16 Сейчас в теме
Спасибо за публикацию. Есть вопрос. Как определяется кодировка в файле? Есть ли возможность определять ее автоматически?
2. Puser-x6 57 13.02.17 08:43 Сейчас в теме
к сожалению без использования сторонних библиотек получить кодировку нельзя.
3. пользователь 19.04.17 09:12
Сообщение было скрыто модератором.
...
Оставьте свое сообщение