10.01.2023 Пётр Быков 10664
Загрузка из Comma-Separated Values (CSV) в ко...

Содержание:

1.      Что такое CSV Comma-Separated Values?

2.      Как загрузить данные из файла CSV в систему программы 1С: Предприятие?  

   

1.      Что такое CSV Comma-Separated Values?


CSV «Comma-Separated Values» — значения разделённые запятыми, это текстовый формат CSV, предназначенный для представления табличных данных. Строка таблицы соответствует строке текста, которая содержит одно или несколько полей, CSV разделенных запятыми.


Зачастую разработчикам ставят задачу загрузки данных в 1С в каком-либо формате, таких как XLS, DOC, TXT, CSV, DBF, XML и т.д. К примеру для разового переноса системы нормативно-справочной информации при переходе с других программ, загрузки 1С контактной информации и дополнительных справочников с сайтов и т.д.


Так как CSV это текстовый формат, то идентичным формату TXT будет и код загрузки в 1С.


В качестве задания нужно будет выгрузить в табличную часть обработки идентичные данные из файла example.txt и example.csv, в строке указано три поля через разделитель «;» (см.рис 1)

            


example.txt и example.csv   

   

2.      Как загрузить данные из файла CSV в систему программы 1С: Предприятие?


Для начала в режиме конфигуратор 1С создадим обработку в которой добавим в шапку два реквизита и табличную часть с тремя реквизитами (колонками) куда будем загружать данные из файла данных формата CSV: (см.рис .2)


Реквизиты шапки

1.      ПутьКФайлу тип Строка длина 256

2.      ФорматФайла тип Строка длина 3


Реквизиты табличной части 

1.Наименование тип Строка длина 150

2.ПолноеНаименование тип Строка длина 256

3.Артикул тип Строка длина 10

   

 

Реквизиты


Далее создаем форму и настраиваем расположение элементов, добавляем и перетаскиваем на форму команду ПрочитатьФайл (см.рис.3)



ПрочитатьФайл


Затем в модуле формы пишем или размещаем данный код. (см.рис.4)


&НаКлиенте

Процедура ПутьКФайлуНачалоВыбора(Элемент, ДанныеВыбора, СтандартнаяОбработка) //Выбор Файла

            Проводник = Новый ДиалогВыбораФайла(РежимДиалогаВыбораФайла.Открытие);

            Проводник.Заголовок = "Выберите нужный файл";

            Если Объект.ФорматФайла = "TXT" Тогда

                        Фильтр = "Тектовый документ (*.txt)|*.txt";

            ИначеЕсли Объект.ФорматФайла = "CSV" Тогда

                        Фильтр = "Тектовый документ (*.csv)|*.csv";

            Иначе

                        Возврат;

            КонецЕсли;

            Проводник.Фильтр = Фильтр;

            Оповещение = Новый ОписаниеОповещения("ПослеВыбораФайла",ЭтотОбъект);

            Проводник.Показать(Оповещение);

           

КонецПроцедуры   

 

&НаКлиенте

Процедура ПослеВыбораФайла(ВыбранныеФайлы,ДополнительныеПараметры)Экспорт // После выбора файла

            Если ВыбранныеФайлы = Неопределено Тогда

                        Возврат;

            КонецЕсли;

            Объект.ПутьКФайлу = ВыбранныеФайлы[0];

КонецПроцедуры

 

 

&НаКлиенте

Процедура ПрочитатьФайл(Команда)             Объект.ДанныеФайла.Очистить(); //Очищаем табличную часть

            Если Объект.ФорматФайла = "TXT" ИЛИ Объект.ФорматФайла = "CSV" Тогда

                        ПрочитатьФайл_TXT_CSV();

            КонецЕсли;

КонецПроцедуры     

&НаКлиенте

Процедура ПрочитатьФайл_TXT_CSV() // Читаем файл

 

            ПоследовательноеЧтение = Истина;  

            Если ПоследовательноеЧтение Тогда

                        Текст = Новый ЧтениеТекста;

                        Текст.Открыть(Объект.ПутьКФайлу,КодировкаТекста.UTF8);

                        ТекСтрока = Текст.ПрочитатьСтроку();

                        Пока ТекСтрока <> Неопределено Цикл

                                    МассивСлов = СтрРазделить(ТекСтрока, ";"); //определеяем разделитель ";"

                                    Если МассивСлов.Количество()< 3 Тогда    //если в строке меньше 3 полей то пропускаем

                                               Продолжить;

                                    КонецЕсли;

                                   

                                               НоваяСтрока = Объект.ДанныеФайла.Добавить();

                                    НоваяСтрока.Наименование = МассивСлов[0];

                                    НоваяСтрока.ПолноеНаименование = МассивСлов[1];

                                    НоваяСтрока.Артикул = МассивСлов[2];

                                   

                                    ТекСтрока = Текст.ПрочитатьСтроку();

                                   

                        КонецЦикла;

                       

            Иначе

                       

                        Текст = Новый ТекстовыйДокумент ;

                        Текст.Прочитать(Объект.ПутьКФайлу,КодировкаТекста.UTF8);

                        Для НомерСтроки=1 По Текст.КоличествоСтрок()Цикл

                                    ТекСтрока = Текст.ПолучитьСтроку(НомерСтроки);

                                    МассивСлов = СтрРазделить(ТекСтрока, ";"); //определеяем разделитель ";"

                                    Если МассивСлов.Количество()< 3 Тогда    //если в строке меньше 3 полей то пропускаем

                                               Продолжить;

                                    КонецЕсли;

                                   

                                    НоваяСтрока = Объект.ДанныеФайла.Добавить();

                                    НоваяСтрока.Наименование = МассивСлов[0];

                                    НоваяСтрока.ПолноеНаименование = МассивСлов[1];

                                    НоваяСтрока.Артикул = МассивСлов[2];

                                   

                        КонецЦикла;

            КонецЕсли;

КонецПроцедуры

 


Процедура


Определяем обработку данных в 1С к какой-нибудь подсистеме. (см.рис.5)



Обработка


Запускаем приложение в режиме запуска «1С Предприятие» и проверяем функциональность обработки, как видим мы добились желаемого результата в обоих случаях выгрузки. (см.рис.6)

 


Загрузка данных из файла


Практически во всех типовых конфигурациях 1С уже присутствуют аналогичные по функционалу обработки.

Пример 1С Бухгалтерия предприятия 3.0 в подсистеме Администрирование – Загрузка данных из файла. (см.рис.7 и 8)



Загрузка данных из файла


Открываем обработку (см.рис.8)                                                                          



Загрузка данных в справочник

   

Специалист компании "Кодерлайн"
Пётр Быков

Наши проекты

ПЭК
ПЭК

Отрасль:
Грузоперевозки

Внедренное типовое решение:
«1С: Управление торговлей»

- Создание прототипа SRM-системы на базе «1С: Управление торговлей»
- Автомат...

ООО «ПКП КАБЭЛЕКТРОСНАБ»
ООО «ПКП КАБЭЛЕКТРОСНАБ»

Отрасль:
Производство кабельной продукции

Внедренное типовое решение:
1С:Управление небольшой фирмой 1.6

- Оформление заказов покупателей;
- Управление складскими запасами;
- Ана...

Автоматизация интеграции с информсистемами клиентов на базе «1С:Предприятие 8. WMS Логистика. Управление складом»
ОАО «Фрейт Линк»

Отрасль:
Логистика и грузоперевозки

Внедренное типовое решение:
«1С:Предприятие 8. WMS Логистика. Управление складом»

– Управление складскими запасами;
– Оформление заказов покупателей;
– ...

Внедрение ПП "1С:CRM ПРОФ" в ООО «Торговый Дом Факел»
ООО «Торговый Дом Факел»

Отрасль:
Производство

Внедренное типовое решение:
1С:CRM ПРОФ

- Управление отношениями с клиентами (CRM) ...

Автоматизация контроля исполнительской дисциплины на базе ПП «1С:Документооборот 8 ПРОФ»
ООО «ФСК Лидер»

Отрасль:
Строительство и девелопмент

Внедренное типовое решение:
1С:Документооборот 8 ПРОФ

- Делопроизводство;
- Учет и хранение документов;
- Учет и контроль исполне...

ООО ХДМ Рус
ООО ХДМ Рус

Отрасль:
Торговля

Внедренное типовое решение:
1С:Управление торговлей

Управление цепочками поставок Оптовая торговля ...

ООО "Смена"
ООО "Смена"

Отрасль:
Торговля, склад, логистика, транспорт

Внедренное типовое решение:
1С:Комплексная автоматизация

Банк и касса
Расчеты с контрагентами
Торговые операции
Взаиморасчеты с...

Автоматизация торговых операций на базе "1С:Управление торговлей" в ОАО "Авиазапчасть"
ОАО «Авиазапчасть»

Отрасль:
Авиационно-космическая промышленность

Внедренное типовое решение:
1С:Управление торговлей

- Оптовая торговля;
- Оформление заказов покупателей;
- Планирование прод...

ООО «Иви.ру»
ООО «Иви.ру»

Отрасль:
Медиаиндустрия

Внедренное типовое решение:
1С:Управление корпоративными финансами

Подсистема казначейства
Модуль бюджетного контроля по ДДС ...

ООО "ЛИКАРД" (Лукойл)
ООО "ЛИКАРД" (Лукойл)

Отрасль:
Нефтесервис

Внедренное типовое решение:
1С:ERP Управление предприятием 2.0

Делопроизводство
• Учет и контроль исполнения поручений
Учет и хранение...

Фирма 1С
Фирма 1С

Отрасль:

Внедренное типовое решение:
1С:Документооборот

- Подготовка функциональной модели прикладного решения «1С:Документооборот...

ООО «Экслтрейд»
ООО «Экслтрейд»

Отрасль:
Торговля

Внедренное типовое решение:
1С:Управление торговлей

Оформление заказов поставщикам Оптовая торговля Торговые операции ...

Наши соц. сети

Telegram-канал «Koderline 1С» Группа в Вконтакте «Кодерлайн КОРП» Rutube

Остались вопросы - обратитесь к нам!

Впишите свои Имя и Телефон, чтобы мы ответили на все интересующие Вас вопросы.
ФИО*
E-mail*
Телефон*
Сообщение