10.01.2023 Пётр Быков 8543
Загрузка из 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С:Документооборот 8 ПРОФ»
ООО «ФСК Лидер»

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

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

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

ПЭК
ПЭК

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

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

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

Внедрение «1С:Зарплата и управление персоналом 8 КОРП» в компании «ПБК»
ООО «Партнер Бухгалтер Консультант»

Отрасль:
Бухгалтерские услуги

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

- Интеграция продукта с базой данных оперативного учета Axapta;
- Доработка функционала подсистемы...

Установка программного продукта БИТ.Финанс для 1С:Бухгалтерия 8
ООО «Джи Эй Си Шиппинг энд Лоджистикс»

Отрасль:
Транспорт

Внедренное типовое решение:
БИТ.Финанс

Построение единого информационного пространства финансовой службы;
Учет бухгалтерский, налоговый, бюджетный, включая регламентированную ...

СТС-Медиа
СТС-Медиа

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

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

- Бухгалтерский учет;
- Налоговый учет;
- МСФО (GAAP/управленческий учет);
- Казначейство...

Автоматизация кадрового учета на базе ПП "1С:Зарплата и управление персоналом" в ТД НМК
ООО «Торговый дом Нальчикский молочный комбинат»

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

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

- Кадровый учет;
- Расчет зарплаты;
- Регламентированная отчетность;
- Анализ кадрового состава;
- Учет рабочего времени; ...

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

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

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

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

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

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

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

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

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

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

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

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

АО «Аэроклуб»
АО «Аэроклуб»

Отрасль:
Услуги в области делового туризма

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

Проведение серии интервью с руководством и ключевыми специалистами Разработка формализованного описания модели существующих бизнес-процессо...

ООО "СЖД"
ООО "СЖД"

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

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

Расчет зарплаты
Подбор кадров
Кадровый учет
Анализ кадрового состава
Учет рабочего времени
Регламентированная отчетность...

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

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

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

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

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

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

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

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