1с создать файл csv
Если файл небольшой можно использовать объект ТекстовыйДокумент (пример чтения )
Текст = Новый ТекстовыйДокумент ;
КоличествоСтрок = Текст . КоличествоСтрок ( ) ;
Для Счетчик = 1 по КоличествоСтрок Цикл
ТекСтрока = Текст . ПолучитьСтроку ( Счетчик ) ;
Сообщить ( ТекСтрока ) ;
КонецЦикла ;
Запись текстового файла
Запись в текстовый файл происходит приблизительно по тому же сценарию: СохранениеФайла = Новый ДиалогВыбораФайла ( РежимДиалогаВыбораФайла . Сохранение ); Текст . Открыть ( СохранениеФайла . ПолноеИмяФайла , КодировкаТекста . ANSI );Пример не содержит проверок на наличие файла, файл перезаписывается. При необходимости добавления используйте метод Прочитать().
Чтение файла CSV
CSV (от англ. Comma-Separated Values — значения, разделённые запятыми) — текстовый формат, предназначенный для представления табличных данных. Каждая строка файла — это одна строка таблицы. Значения отдельных колонок разделяются разделительным символом (delimiter) — запятая (,) или точка с запятой (;). (Википедия) Такой формат часто используют для выгрузки данных из различных баз отличных от 1С. Ниже представлен алгоритм чтения данного формата на основе обычного чтения текстового файла с анализом строки и разбиением ее на поля. ВыборФайла = Новый ДиалогВыбораФайла ( РежимДиалогаВыбораФайла . Открытие ); //Создаем массив в который будем добавлять выбранные поля //Удаляем из строки найденную подстроку и повторяем цикл с оставшейся строкой Попытка Сообщить ( МассивПолей [ 0 ]); Исключение КонецПопытки;Подведем итоги:
Для чтения и записи текстового файла в 1С существуют 3 объекта ЧтениеФайла, ЗаписьФайла, ТекстовыйДокумент.
Возможно использовать данные функции для чтения/записи HTML и log файлов.
Для работы с XML (хотя они тоже текстовые) рекомендуется использовать специализированные объекты ЧтениеXML, ЗаписьXML.
Реклама — самая интересная и самая трудная форма современной литературы.
— Олдос Леонард Хаксли
Увы! Статья не может состоять только из кода. После некоторых раздумий я решился осквернить этот скрижаль мысли в рамках RFC4180, квинтэссенцию материализации файла с разделителями на накопителях и прочее и прочее своим косноязычным описанием сего таинства.
Пролью свет и приоткрою глаза начинающего программиста Архипа на это чудо. Итак, слушай, о достопочтенный начинающий программист Архип.
Прежде всего должен ты получить таблицу значений. Самый простой способ - написать запрос и выгрузить результат в упомянутую мной сущность бытия данных. Затем надо определиться с именем файла. После этого дозволь обратить твой взор, о начинающий программист Архип, на функцию СоздатьДанныеCSV(таблицаЗначений, разделитель = ",", выводитьЗаголовок = ЛОЖЬ). В эту функцию передается та самая таблица значений, полученная из запроса. А кроме нее разделитель полей. А потом принять ответственное решение на заполнение первой строки названиями колонок этой самой, выше упомянутой таблицы значений (см. функцию СоздатьЗаголовкиCSV).
А дальше таблица значений будет читаться построчно, и каждая строка ее будет превращаться в сроковое значение в соответствии с заклинанием манускрипта СоздатьСтрокуCSV(запись,разделитель).
Специальные предложения
привел, RFC4180, гугл знает где взять и даже переводит сносно И можно еще чуть модифицировать и получится универcальный код для создания .csv и .tsv =) (2) Nati4ka,
вроде ничего не надо там модифицировать, только поменять на разделитель = Символ.Таб Боюсь ошибку выдаст программа сия, о достопочтенный учитель, в случае когда надо вывести заголовки.
В функции СоздатьЗаголовкиCSV нет начального описания переменной стрКолонки. (5) it-on,
Ну зачем так сразу-то, на весь класс. Решил - поднял руку, получил пять.
(6) Прости учитель. С первого класса у меня так - сначала скажу, потом подумаю, а часто и не подумаю - скажу. Из-за чего часто выгоняли в коридор.
На длинных таблицах код будет быстро деградировать по производительности. И только эта деградация спасёт от переполнения памяти. Тут либо уж сразу в файл писать, либо использовать ЗаписьXML как StringBuilder.
Вот пример. Учтите только, что этому коду уже 6 лет.
(8) speshuric,Все так. Нужно будет выгрузить большие объемы - деградируем. Хотя csv и большие объемы - сомнительный союз. (12)
Не соглашусь. Именно CSV нереально рулит на больших объёмах. Какие другие варианты в родном 1С-коде? XML - это вообще нецензурно. DBF - ограничение в сколько-то гигов (то ли 2 то ли 4 то ли еще что-то подобное). JSON - слишком молодо и оверхэд всё равно заметный. Табличный документ (в MXL или XLSX) сдохнут в районе миллиона строк. Остаются только внешние источники данных (или сразу ADO), там можно по частям запихивать, но не все получатели могут через ODBC/ADO. Все остальные средства - неродные вроде бы. И вот - единственный финалист CSV - благо во всех языках, в том числе 1С, его прочитать можно последовательно. Но и CSV в памяти тогда весь держать не следует, конечно же. (13) speshuric,
Ok, прозвучало убедительно, после праздников выпущу в свет второй комплект процедур и функций для больших массивов. (12) скажите это тем, кто выгружает файл о недействительных паспортах - там 1 гиг в CSV. (14) starik-2005,
про паспорта мне комментировать сложно, не тот профиль. Но есть предположение что, что-то не то в регламенте обмена. У меня получается на 1 недействительный паспорт 4+6+6 символов, плюсом 3 запятых. Итого 20(21) символ на запись с учетом ПС. 1073741824 /21=51130563 паспортов. Каждый третий в стране поменял паспорт. Интересно за какой период эта выборка? (18) starik-2005,
добавил еще код подразделения, выдававшего паспорт, но видимо лишнее За сказку 5, а за повествование 2! Ну кто в такой манере статью пишет.
Ну есть же в формате вариант для описания нулевого значения!
Дальше если в поле есть символ ( " ), то вы такое поле помещаете в кавычки:
Если на входе будет такая строка, то что получится:
В итоге все преобразуется в строку:
Как это распарсится при чтении? Хреново. В действительности, надо все символы ( " ) заменить на символы ( "" ), т.е. так:
Что, я один это увидел?
(10) starik-2005,чуть выше проверки на кавычку в строке есть строка, предлагаемый Вами вариантом с заменой кавычки на пару кавычек
так-что вроде все справедливо.
А насчет 0 у числового значения: у 1С трудно понять в числовом значении где 0, а где NULL.Поэтому и проверяю если тип = ЧИСЛО и пусто, то пусть будет 0, а не пустое значение. Хотя вопрос интересный. Или имелось ввиду
кг/ам, но все-таки взял на себя смелость перевести этот rfc4180 :Общий формат и MIME-тип для значений, разделенных запятыми (CSV файлов)
В то же время, различные программы и операционные системы с низапямятных времен используют различные MIME-типы для этого формата. Этот RFC документ официально регистрирует "text/csv" MIME-тип для CSV в соответствии с RFC 2048 [1].
В то время как существуют различные реализации и спецификации для CSV формата
(напр. [4], [5], [6] и [7]), не существует ни одной официальной спецификации
в настоящее время, что позволяет существовать множеству разнообразных
интерпретации CSV файлов. Этот раздел описывает формат, которому, похоже,
следуют большинство реализаций:
1. Записи расположены на отдельных строках, разделенных символом разрыва
строки (CRLF). Например:
ааа, bbb, ссс CRLF
zzz, ууу, ххх CRLF
2. Последняя запись в файле может иметь или не иметь перенос строки.
Например:
ааа, bbb, ссс CRLF
zzz, ууу, ххх
3. Опционально и совсем необязательно в первой строке файла может быть
расположен заголовокв том же формате, как и для обычных записей строк.
Этот заголовок будет являться именами соответствующих полей в файле и
должн содержать такое же количество полей, как записи в остальной части
файла (наличие или отсутствие строки заголовка должно быть указано с
помощью дополнительного параметра этого MIME-типа). Например:
field_name, field_name, field_name CRLF
ааа, bbb, ссс CRLF
zzz, ууу, ххх CRLF
4. В пределах заголовка и каждой записи, может быть одно или более
полей, разделенных запятыми. Каждая строка должна содержать то же самое
количество полей по всему файлу. Пробелы считаются частью поля и не
должны игнорироваться. Последнее поле в записи не должна оканчиваться
запятой. Например:
5. Каждое поле может быть (а может и не быть) заключено в двойные
кавычки (однако некоторые программы, такие как Microsoft Excel, могут не
использовать двойные кавычки вообще). Поля, не заключеные в двойные
кавычки, не могут содержать двойные кавычки внутри полей. Например:
"ааа", "bbb", "ccc" CRLF
zzz, ууу, ххх
6. Поля, содержащие разрывы строки (CRLF), двойные кавычки, или запятые
должены быть заключены в двойные кавычки. Например:
"ааа", "b CRLF
bb ","ccc" CRLF
zzz, ууу, ххх
7. Если двойная кавычка используется внутри заключенного поля, то она
должна быть экранирована другой двойной кавычкой. Например:
ABNF грамматика (англ. augmented Backus-Naur form — расширенная форма
Бэкуса — Наура) [2] выглядит следующим образом:
file = [header CRLF] record *(CRLF record) [CRLF]
header = name *(COMMA name)
record = field *(COMMA field)
field = (escaped / non-escaped)
escaped = DQUOTE *(TEXTDATA / COMMA / CR / LF / 2DQUOTE) DQUOTE
CR = %x0D ;как указано в разделе 6.1 RFC 2234 [2]
DQUOTE = %x22 ;как указано в разделе 6.1 of RFC 2234 [2]
LF = %x0A ;как указано в разделе 6.1 of RFC 2234 [2]
CRLF = CR LF ;как указано в разделе 6.1 of RFC 2234 [2]
TEXTDATA = %x20-21 / %x23-2B / %x2D-7E
Этот раздел содержит media-type описание приложений (в соответствии
с RFC 2048 [1]).
Повсеместно использование CSV в US-ASCII, но и другие кодировки могут
быть использованы в сочетании с параметром "Charset" .
Параметр "header" указывает на наличие или отсутствие строки заголовка.
Допустимые значения "present" или "absent". Разработчики могут не
использовать этот параметр должен самостоятельно принимать решение
относительно того, присутствует или отсутствует строка заголовка.
Как указано в разделе 4.1.1 RFC 2046 [3], этот media-тип использует CRLF
для обозначения разрыва строки, однако, разработчики должны знать, что
некоторые реализации могут использовать другие значения.
CSV-файлы содержат пассивный текстовые данные которые не должны создавать
каких-либо рисков. Тем не менее, теоретически возможно, что злонамеренные
двоичные данные могут быть включены для того, чтобы использовать
потенциальное переполнение буфера в программе обработки CSV данных.
Кроме того, частные данные могут быть переданы через этот формат (что,
конечно, относится к любому текстовых данных).
Из-за отсутствия единой спецификации, существуют значительные
различия между реализациями. Разработчики, вы должны "быть
консервативными в том, что вы делаете, и быть либеральным в том,
что вы принимаете от других"(RFC 793 [8]), когда делаете обработку
файлов CSV. Попытка создать общее определение можно найти в разделе 2.
Разработчик, решенив не использовать параметр "header" должен принимать
самостоятельно решение относительно того, присутствует ли заголовок
или отсутствует.
В то время как множество собственных спецификации существуют для различных программ и систем, не существует ни одного «хозяина» спецификации для этого формата. Попытка общего определения можно найти в разделе 2.
Приложения, использующие этот media-тип:
Электронные таблицы и различные утилиты преобразования данных.
Магическое число: нет
Расширение файла: CSV
Macintosh тип файла: TEXT
Email для получения дополнительной информации:
Назначение использования: ОБЩЕЕ
Автор / Контроллер: IESG
4. Соображения IANA
IANA зарегистрировал MIME-тип "text/csv" с помощью
приложения, предусмотреного в разделе 3 настоящего документа.
5. Вопросы безопасности
См обсуждение выше в разделе 3.
6. Выражаю признательностт
Автор хотел бы поблагодарить Dave Crocker, Martin Duerst, Joel M.
Halpern, Clyde Ingram, Graham Klyne, Bruce Lilly, Chris Lilley, и
членов IESG за их полезные предложения. Особое слово
благодарности Дэйву за помощь с грамматикой ABNF.
Особая благодарность L.T.S.
7.1. Нормативные ссылки
[1] Freed, Н., Кленсин, J., и J. Постел, "Интернет Многоцелевой
Mail Extensions (MIME) Часть четвертая: Процедуры регистрации ", BCP
13, RFC 2048, ноябрь 1996 года.
[2] Крокер, Д. и П. Overell, "Augmented BNF для синтаксиса
Технические характеристики: ABNF ", RFC 2234, ноябрь 1997 года.
[3] Freed, Н. и Н. Borenstein, "Многоцелевой Internet Mail
Расширения (MIME) Часть вторая: Типы носителей ", RFC 2046, ноябрь
1996.
7.2. Информативные ссылки
[8] Постел, J., "Протокол управления передачей", STD 7, RFC 793,
Сентябрь 1981.
Yakov Shafranovich
SolidMatrix Technologies, Inc.
Собственно самая интересная часть:
file = [header CRLF] record *(CRLF record) [CRLF]
header = name *(COMMA name)
record = field *(COMMA field)
name = field
field = (escaped / non-escaped)
escaped = DQUOTE *(TEXTDATA / COMMA / CR / LF / 2DQUOTE) DQUOTE
non-escaped = *TEXTDATA
TEXTDATA = %x20-21 / %x23-2B / %x2D-7E
//*** Если есть шапка таблицы ***
Шапка_CSV = Файл_CSV . ПолучитьСтроку ( 1 );
// Чтение и разделение на отдельные значения в массив (по разделителю)
Массив_CSV = СтрРазделить ( Шапка_CSV , Используемый_разделитель );
//***************************
Для Каждого СтрокаНом Из Массив_CSV Цикл
// Удаляем пробелы т.к. в названии столбцов они не допускаются
ИмяБП = СтрЗаменить ( СтрокаНом , " " , "" );
ТЗ . Колонки . Добавить ( ИмяБП ,, СтрокаНом );
Для НомерСтроки = 2 по Файл_CSV . КоличествоСтрок () Цикл // Если без шапки, то начинаем с первой строчки
// Получаем строку по-порядку
Строка_CSV = Файл_CSV . ПолучитьСтроку ( НомерСтроки );
// Разделяем с помощью выбранного разделителя каждую строку на столбцы
Массив_CSV = СтрРазделить ( Строка_CSV , Используемый_разделитель );
НоваяСтрочка = ТЗ . Добавить (); // Добавляем строку в ТЗ
Для Ном_Столбца = 1 по Массив_CSV . Количество () Цикл
ТекЗначение_CSV = Массив_CSV [ Ном_Столбца - 1 ];
ИмяКолонки_CSV = ТЗ . Колонки [ Ном_Столбца - 1 ]. Имя ;
НоваяСтрочка [ ИмяКолонки_CSV ] = ТекЗначение_CSV ;
Используемый_разделитель = ";" ;
Файл_CSV = "D:\import_21092020.csv" ;
//*** Получаем данные из запроса ***
Запрос = Новый Запрос ;
Запрос . Текст =
"ВЫБРАТЬ
| ВнутреннийПрайс.Код КАК Код,
| ВнутреннийПрайс.Наименование КАК Наименование,
| ВнутреннийПрайс.ЗакупочнаяЦена КАК ЗакупочнаяЦена,
| ВнутреннийПрайс.РозничнаяЦена КАК РозничнаяЦена,
| ВнутреннийПрайс.ОптоваяЦена КАК ОптоваяЦена
|ИЗ
| Справочник.Цены КАК ВнутреннийПрайс" ;
РезультатЗапроса = Запрос . Выполнить (). Выгрузить ();
ТаблицаЗначений = РезультатЗапроса ;
//**********************************
Текст_CSV = "" ; // Текст с учетом заголовков, разделителей и переноса строк
Для Каждого СтрокаТЗ из ТаблицаЗначений Цикл
Если Текст_CSV = "" тогда
СтрокаКол = "" ;
КолонкиТЗ = ТаблицаЗначений . колонки ;
Для Каждого Каждая_Колонка Из КолонкиТЗ Цикл
СтрокаКол = "" + СтрокаКол + Каждая_Колонка . Имя + Используемый_разделитель ;
КонецЦикла;
Текст_CSV = СтрокаКол + Символы . ПС ;
Текст_CSV = Текст_CSV + СтрокаТЗ . Код + Используемый_разделитель + СтрокаТЗ . Наименование
+ Используемый_разделитель + СтрокаТЗ . ЗакупочнаяЦена + Используемый_разделитель + СтрокаТЗ . РозничнаяЦена
+ Используемый_разделитель + СтрокаТЗ . ОптоваяЦена + Символы . ПС ;
КодANSI = КодировкаТекста . ANSI ;
ТекстовыйФайлЗапись = Новый ЗаписьТекста ( Файл_CSV , КодANSI ); // Создание файла CSV
ТекстовыйФайлЗапись . ЗаписатьСтроку ( Текст_CSV ); // Запись информации в файл
ТекстовыйФайлЗапись . Закрыть (); // Обязательно закрываем, иначе зависает в процессе
Форма импорта (Контент > Информационные блоки > Импорт > CSV) предназначен для импорта данных в формате CSV в информационный блок.
Шаг 1. Файл данных
Форма предназначена для выбора загружаемого файла и информационного блока, в который будет выполняться загрузка данных.
Поле | Описание |
---|---|
Файл данных | С помощью кнопки Обзор выберите файл с загружаемыми данными. |
Информационный блок | Выберите сначала тип информационного блока, а затем и сам блок, в который будет выполняться загрузка данных. |
Шаг 2. Формат
- с разделителями - поля разделяются специальным символом (например, запятой или пробелом);
- фиксированная ширина полей.
Шаг 3. Поля
Форма служит для задания соответствия между полями инфоблока и загружаемого файла.
Важно! Обязательно должно быть выбрано хотя бы одно из полей Уникальный идентификатор (B_IBLOCK_ELEMENT.XML_ID) или Название (B_IBLOCK_ELEMENT.NAME). Эти поля используются для сопоставления записей в файле записям в базе данных.
Также проверьте настройки инфоблока В данном примере опция Начало активности отмечена как обязательная, поэтому в создаваемом
файле csv тоже должна быть колонка с указанием начала активности элемента.
( Контент > Инфоблоки > Типы инфоблоков > [ваш тип инфоблока]/[ваш инфоблок] ), в который Вы хотите загрузить файл: если во вкладках Поля или Поля разделов какие-либо поля отмечены как обязательные, то эти колонки должны быть обязательно и в загружаемом csv-файле.
Внимание! Убедитесь, что соответствия полей заданы корректно. В противном случае результат загрузки непредсказуем.
- деактивировать - элементы инфоблока станут неактивными;
- удалить - элементы будут удалены;
- не трогать - элементы будут сохранены без изменений.
- оставить как есть - элементы/группы не будут изменены;
- активировать - элементы/группы станут активными (т.е. доступными для показа в публичном разделе).
Шаг 4. Результат
Выводится информация о результатах загрузки данных. Для того чтобы повторить загрузку данных или импортировать данные из другого CSV файла, нажмите кнопку Вернуться на первый шаг.
Смотри также
Пользовательские комментарии
Мы будем рады, если разработчики добавят свои комментарии по практическому использованию методов системы.
Для этого нужно всего лишь авторизоваться на сайте
Но помните, что Пользовательские комментарии, несмотря на модерацию, не являются официальной документацией. Ответственность за их использование несет сам пользователь.
Также Пользовательские комментарии не являются местом для обсуждения функционала. По подобным вопросам обращайтесь на форумы.
Читайте также: