10.01.2023 Пётр Быков 10147
Загрузка из 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С:Управление торговлей" в ОАО "Авиазапчасть"
ОАО «Авиазапчасть»

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

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

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

Московский филиал ООО «Авиакомпания «Икар»
Московский филиал ООО «Авиакомпания «Икар»

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

Внедренное типовое решение:
1С:Бухгалтерия КОРП

Бухгалтерский учет Производственные операции Регламентированная отчетнос...

Внедрение блоков в 1С:Комплексная автоматизация 8
ООО «Больцен Рус»

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

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

- Оперативный учет...

ООО «ДАФ Тракс Рус» (DAF Trucks Rus)
ООО «ДАФ Тракс Рус» (DAF Trucks Rus)

Отрасль:
Машиностроение

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

- Осуществлена разработка матрицы прав и ролей для финансового подразделени...

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

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

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

- Оформление заказов поставщикам;
- Управление отношениями с поставщиками;...

ООО "ТК "Сытый Дом-НН"
ООО "ТК "Сытый Дом-НН"

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

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

Взаиморасчеты с покупателями
Оптовая торговля
Управление складскими за...

ООО "АСК ИНЖИНИРИНГ"
ООО "АСК ИНЖИНИРИНГ"

Отрасль:
Машиностроение, приборостроение

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

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

МГК "Световые Технологии"
МГК "Световые Технологии"

Отрасль:

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

Специалисты "Кодерлайн" произвели доработки в системе 1С:ЕРП 2.4 с учетом треб...

Внедрение блока расчета себестоимости РАУЗ в 1С:УПП 8
ООО «Пелигрин Матен»

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

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

– Оформление заказов покупателей;
– Взаиморасчеты с покупателями;
– О...

Внедрение 1С:Управление торговлей в оптово-розничной компании «Много Плитки»
ООО «Много Плитки»

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

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

Закупки (снабжение) и управление отношениями с поставщиками:
- Оформление ...

Московский филиал ООО «Авиакомпания «Икар»
Московский филиал ООО «Авиакомпания «Икар»

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

Внедренное типовое решение:
1С:Зарплата и управление персоналом

Управление персоналом и кадровый учет (HRM) Кадровый учет Расчет зарплаты Рег...

ОАО «Интер РАО – Электрогенерация»
ОАО «Интер РАО – Электрогенерация»

Отрасль:
Электрогенерация

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

Для работы 2500 пользователей в 9 часовых поясах организована территориально-...

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

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

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

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