Выгрузка 1С

1С:Предприятие 8.2 /
Установка 1С:Предприятие 8.2

В каких случаях нужна выгрузка данных из 1С 8.2? Наиболее частые случаи, встречающиеся на практике:

  • Создание резервной копии данных в 1С

  • Создание копии базы, хранящейся на сервере

  • Перенос данных с одного компьютера на другой

  • Сохранение данных для переустановки ОС.

Для выгрузки данных из 1С 8.2 необходимо выбрать свою базу данных и запустить программу в режиме Конфигуратор.

Выбираем в меню Администрирование команду » Выгрузить информационную базу «

Указываем как сохраним файл с выгрузкой – это может быть папка с резервными копиями, рабочий стол или флешка.

По окончанию процесса выгрузки отобразится соответствующие сообщение.

Для переноса данных на другой компьютер необходимо на нем выполнить загрузку данных.

Нас находят: как сохранить базу 1с 8 2 на флешку, как скопировать базу 1с 8 2 на флешку, как выгрузить базу 1с 8 2 на флешку, как выгрузить базу 1с на флешку, как скачать базу 1с на флешку, как скопировать базу 1с 8 на флешку, как сохранить 1с на флешку, как сохранить базу 1с 8 3 на флешку, как скопировать базу 1с на флешку, как скопировать базу 1с 8 3 на флешку

Описание функции ВыгрузитьПоПравилу().

Функция ВыгрузитьПоПравилу() используется для выгрузки объекта в xml-узел и возвращает узел ссылки на этот объект.

В процессе выгрузки эта функция вызывается из:

ПВД, когда объект из выборки получен и необходимо произвести его конвертацию.

ПКО, когда необходимо выгрузить связанную с выгружаемым объектом информацию.

ПКС, когда свойство имеет ссылочный тип и необходимо выгрузить по ссылке из этого свойства объект.

Из функции ВыгрузитьПоПравилу() могут быть вызваны другие функции, выгружающие субконто, свойства и т.д. этого объекта, а из этих функций – рекурсивно может быть вызвана функция ВыгрузитьПоПравилу(). После того, как объект со всеми необходимыми свойствами выгружен, управление возвращается в то место кода, откуда функция была вызвана. Таким образом, вызов этой функции из обработчиков событий какого-либо правила (ПВД, ПКО, ПКС), не изменяет процесса выгрузки объекта по этому правилу.

Функция ВыгрузитьПоПравилу() имеет ряд параметров
ВыгрузитьПоПравилу(Источник,
Приемник,
ВходящиеДанные,
ИсходящиеДанные,
ИмяПКО,
УзелСсылки,
ТолькоПолучитьУзелСсылки,
ПКО,
ЭтоПравилоСГлобальнойВыгрузкойОбъектов,
ВыборкаДляВыгрузкиДанных)

Все эти параметры в функции имеют значения по умолчанию, и, как правило, передавать имеет смысл только параметр ИмяПКО, а также параметры Источник и/или ВходящиеДанные – в зависимости от того, как настроено ПКО.

ИмяПКО – строка, название ПКО, в которое передаем управление.
Источник – ссылка на элемент объекта-источника, который передаем для конвертации.
ВходящиеДанные – структура. Элементы в ней должны быть названы аналогично ПКС, у которых стоит флаг «Получить из входящих данных». Если таких ПКС нет, передавать этот параметр не нужно. Если в ПКО у всех ПКС стоит флаг «Получить из входящих данных», то, наоборот, необходимо передать структуру ВходящиеДанные, а Источник тогда передавать не нужно.

Выгрузка произвольной выборки данных через стандартную выборку с регистрацией объекта источника.

Необходимость в такой задаче может возникнуть, когда объект «источника» и объект «приемника» имеют различную смысловую или функциональную структуру.

Например, документ «источника» позволяет вводить информацию по нескольким подразделениям предприятия, документ «приемника» позволяет вводить информацию только об одном подразделении предприятия.

Данная задача отлично решается при помощи произвольного алгоритма выборки в ПВД, но данное решение имеет два недостатка:

  1. Мы лишаемся механизма регистрации изменений;
  2. Алгоритм произвольной выборки отказывается работать в БСП.

БСП — библиотека стандартных подсистем. В частности, имеет своем составе подсистему «Обмен данными», данная подсистема реализует механизмы автоматической синхронизации данных между конфигурациями, по правилам написанным в Конвертации данных.

  1. Создаем ПВД со Стандартным алгоритмом выборки;
  2. Указываем объект выборки;
  3. Пишем обработчик «Перед выгрузкой»(хочу подчеркнуть, что нужно использовать именно этот обработчик). Например, следующего содержания:

//Начинаем отбор данных для выгрузки Запрос = Новый Запрос; Запрос.Текст = «ВЫБРАТЬ РАЗЛИЧНЫЕ | ПриемНаРаботуВОрганизациюРаботникиОрганизации.Сотрудник, | ПриемНаРаботуВОрганизациюРаботникиОрганизации.ПодразделениеОрганизации КАК Подразделение, | ПриемНаРаботуВОрганизациюРаботникиОрганизации.Должность, | ПриемНаРаботуВОрганизациюРаботникиОрганизации.ЗанимаемыхСтавок КАК Ставка, | ПриемНаРаботуВОрганизациюРаботникиОрганизации.ДатаПриема, | ПриемНаРаботуВОрганизациюРаботникиОрганизации.Сотрудник.ВидЗанятости КАК ВидЗанятости, | ПриемНаРаботуВОрганизациюРаботникиОрганизации.Ссылка.Дата, | ПриемНаРаботуВОрганизациюРаботникиОрганизации.Ссылка.Номер, | ПриемНаРаботуВОрганизациюРаботникиОрганизации.Ссылка.Проведен, | ВЫБОР | КОГДА ПриемНаРаботуВОрганизациюОсновныеНачисления.ВидРасчета = ЗНАЧЕНИЕ(ПланВидовРасчета.ОсновныеНачисленияОрганизаций.ОкладПоЧасам) | ТОГДА ИСТИНА | ИНАЧЕ ЛОЖЬ | КОНЕЦ КАК СдельнаяОплатаТруда, | ПриемНаРаботуВОрганизациюОсновныеНачисления.ВидРасчета КАК ВидРасчета |ИЗ | Документ.ПриемНаРаботуВОрганизацию.РаботникиОрганизации КАК ПриемНаРаботуВОрганизациюРаботникиОрганизации | ВНУТРЕННЕЕ СОЕДИНЕНИЕ Документ.ПриемНаРаботуВОрганизацию.ОсновныеНачисления КАК ПриемНаРаботуВОрганизациюОсновныеНачисления | ПО ПриемНаРаботуВОрганизациюРаботникиОрганизации.Ссылка = ПриемНаРаботуВОрганизациюОсновныеНачисления.Ссылка | И ПриемНаРаботуВОрганизациюРаботникиОрганизации.Сотрудник = ПриемНаРаботуВОрганизациюОсновныеНачисления.Сотрудник |ГДЕ | ВЫБОР | КОГДА &ИспользоватьОтборПоПодразделениям ТОГДА | ПриемНаРаботуВОрганизациюРаботникиОрганизации.ПодразделениеОрганизации В ИЕРАРХИИ (&Подразделения) | ИНАЧЕ | ИСТИНА | КОНЕЦ | И ВЫБОР | КОГДА &ИспользоватьОтборПоВидамРасчета ТОГДА | ПриемНаРаботуВОрганизациюОсновныеНачисления.ВидРасчета В ИЕРАРХИИ (&ВидРасчета) | ИНАЧЕ | ИСТИНА | КОНЕЦ | И ПриемНаРаботуВОрганизациюРаботникиОрганизации.Ссылка = &Ссылка»; Выполнить(Алгоритмы.ЗаполнитьПараметрыОтбораПоВидамРасчета); Запрос.УстановитьПараметр(«Ссылка», Объект.Ссылка); Выполнить(Алгоритмы.ЗаполнитьПараметрыОтбораПоПодразделениям); ВыбранныеДанные = Неопределено; ПустаяТабличнаяЧасть = Неопределено; Выполнить(Алгоритмы.ПолучитьСтруктуруВыгрузкиКадровыхДокументов); РезультатЗапроса = Запрос.Выполнить().Выгрузить(); Сотрудники = ПустаяТабличнаяЧасть.Скопировать(); СтрокаДокумента = Неопределено; Для Каждого СтрокаРезультата Из РезультатЗапроса Цикл ДанныеИзВнешнихСистем = «Выгружено из ЗиКБУ, документ «»Прием на работу в организацию»» №» + СтрокаРезультата.Номер + » от » + Формат(СтрокаРезультата.Дата, «ДФ=dd.MM.yyyy») + «, » + СтрокаРезультата.Подразделение.Наименование; СтрокаДокумента = ВыбранныеДанные.Найти(ДанныеИзВнешнихСистем); Если СтрокаДокумента = Неопределено Тогда СтрокаДокумента = ВыбранныеДанные.Добавить(); СтрокаДокумента.Дата = СтрокаРезультата.ДатаПриема; СтрокаДокумента.Кафедра = СтрокаРезультата.Подразделение; СтрокаДокумента.Проведен = СтрокаРезультата.Проведен; СтрокаДокумента.ДокументСАктивнымиДолжностями = Истина; СтрокаДокумента.ДанныеИзВнешнихСистем = ДанныеИзВнешнихСистем; СтрокаДокумента.АктивныеДолжности = ПустаяТабличнаяЧасть.Скопировать(); СтрокаДокумента.НеактивныеДолжности = ПустаяТабличнаяЧасть.Скопировать(); КонецЕсли; СтрокаРаботников = СтрокаДокумента.АктивныеДолжности.Добавить(); СтрокаРаботников.Должность = СтрокаРезультата.Должность; СтрокаРаботников.Сотрудник = СтрокаРезультата.Сотрудник.Физлицо; СтрокаРаботников.Ставка = СтрокаРезультата.Ставка * 100; СтрокаРаботников.ВидНачисления = СтрокаРезультата.ВидРасчета; СтрокаРаботников.ВидЗанятости = СтрокаРезультата.ВидЗанятости; КонецЦикла; //Переводим отобранные данные из Таблицы значений в Массив структур для дальнейшей передачи в ПКО ДокументыЗакреплениеЗаКафедрой = Неопределено; Выполнить(Алгоритмы.ПереводТаблицыЗначенийВМассивЗакреплениеЗаКафедрой); //Обходим отобранные данные и выгружаем с помощью функции ВыгрузитьПоПравилу Для каждого Документ Из ДокументыЗакреплениеЗаКафедрой Цикл ВыгрузитьПоПравилу(,,Документ,,»ЗакреплениеЗаКафедройИзВходящихДанных»); КонецЦикла; //Отменяем стандартную выгрузку объекта Отказ = Истина;

Большую часть этого обработчика, как вы можете видеть, занимает отбор данных необходимых для выгрузки. Тут и множество фильтров: по подразделениям, по видам расчетов и механизм разбиения одного документа «источника» на несколько документов «приемника». Если коротко, то в данном примере табличная часть одного документа «источника» разносится по табличным частям нескольких документов «приемника», а значением разбиения данных является значение Подразделения.
Для удобства работы при отборе данных мы использовали Таблицу значений, наш алгоритм подразумевает ПКО с получением данных из «входящих данных», которые будут переданы в функцию ВыгрузитьПоПравилу, поэтому в соответсвующем алгоритме мы производим перевод Таблицы значений в Массив структур.
На следующем шаге мы обходим отобранные данные и вот уже в этом месте мы используем нашу функцию ВыгрузитьПоПравилу. Параметр Документ, здесь является структурой, которую мы передаем как входящие данные, а второй передаваемый нами параметр, это название ПКО, которому мы передаем наши данные.
В самом конце мы отменяем выполнение стандартной выгрузки, так как все необходимые данные связанные с объектом выборки мы уже выгрузили.
Тем самым мы сохраняем функциональность регистрации изменений — документ изменился, зарегистрировался для выгрузки, данные выгрузили. И в то же время делаем произвольный отбор необходимых нам данных.

В ПКО в этом случае для свойств необходимо указать, что они получаются из «Входящих данных».

Выгрузка Регистр сведений -> Регистр сведений с зависимостью от переноса другого объекта.

Типичным примером такой задачи является перенос контактной информации физического лица. Простейший способ решения задачи — это перенос всех «Физических лиц» и всего регистра сведений «Контактная информация» физических лиц. Что делать если нам необходимо переносить не всех физических лиц? Например, только тех физических лиц, которые упоминаются в каком-либо переносимом нами документе. В таком случае, как известно, ПКС документа вызывает ПКО справочника «Физические лица» и тем самым обеспечивается перенос физических лиц упоминаемых в документе.

В переносе «Контактной информации» физических лиц в данной ситуации может помочь функция ВыгрузитьРегистр, очень похожая на функцию ВыгрузитьПоПравилу.

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

В обработчике»После выгрузки в файл» ПКО «Физические лица», пишем код следующего вида:

////////////////////////////////////////////////////// //Выгрузим контактную информацию типа Адрес Запрос = Новый Запрос; Запрос.Текст = «ВЫБРАТЬ | КонтактнаяИнформация.Представление, | КонтактнаяИнформация.Вид, | КонтактнаяИнформация.Тип, | КонтактнаяИнформация.Объект |ИЗ | РегистрСведений.КонтактнаяИнформация КАК КонтактнаяИнформация |ГДЕ | КонтактнаяИнформация.Тип = ЗНАЧЕНИЕ(Перечисление.ТипыКонтактнойИнформации.Адрес) | И КонтактнаяИнформация.Вид В (ЗНАЧЕНИЕ(Справочник.ВидыКонтактнойИнформации.ЮрАдресФизЛица), ЗНАЧЕНИЕ(Справочник.ВидыКонтактнойИнформации.ФактАдресФизЛица)) | И КонтактнаяИнформация.Объект = &Объект»; Запрос.УстановитьПараметр(«Объект», Источник); Выборка = Запрос.Выполнить ().Выбрать (); Пока Выборка.Следующий () Цикл Отбор = Новый ТаблицаЗначений; Отбор.Колонки.Добавить («Имя»); Отбор.Колонки.Добавить («Значение»); Отбор.Колонки.Добавить («Использование»); СтрокаОтбора = Отбор.Добавить (); СтрокаОтбора.Имя = «Объект»; СтрокаОтбора.Значение = Выборка.Объект; СтрокаОтбора.Использование = Истина; Строки = Новый ТаблицаЗначений; Строки.Колонки.Добавить(«Представление»); Строки.Колонки.Добавить(«Вид»); Строки.Колонки.Добавить(«Тип»); Строки.Колонки.Добавить(«Объект»); Строка = Строки.Добавить(); Строка.Представление = Выборка.Представление; Строка.Вид = Выборка.Вид; Строка.Тип = Выборка.Тип; Строка.Объект = Выборка.Объект; НаборЗаписей = Новый Структура(«Отбор, Строки»); НаборЗаписей.Отбор = Отбор; НаборЗаписей.Строки = Строки; ВыгрузитьРегистр(НаборЗаписей,,,,»КонтактнаяИнформация»); КонецЦикла;

Как видно, в коде отбираются все записи регистра сведений, относящиеся к текущему выгружаемому Физическому лицу, а полученная выборка обходится в цикле.

Для того, чтобы выгрузить записи регистра сведений через функцию ВыгрузитьРегистр, необходимо подготовить структуру НаборЗаписей, которая имеет два поля: Отбор и Строки.

ПКО «КонтактнаяИнформация» имеет следующий вид:

Выгрузка Табличная часть -> Регистр сведений.

По своему решению задача аналогична предыдущей. С той лишь разницей, что информацию для регистра сведений «приемника» брать придется из других объектов «источника», а точнее табличной части того объекта, который на данный момент выгружается. Если бы на стороне «приемника» была так же табличная часть, то задача легко решалась бы в виде ПГКС. Поэтому снова воспользуемся функцией ВыгрузитьРегистр.

Рассмотрим пример переноса информации по ученым степеням Физического лица. Опять создаем код в обработчике «После выгрузки в файл» ПКО «Физические лица». Так как задача аналогичная предыдущей привожу только, код отбора и выгрузки данных из обработчика:

/////////////////////////////////////////////////////// //Выгрузим информацию по ученым степеням Запрос = Новый Запрос; Запрос.Текст = «ВЫБРАТЬ | ФизическиеЛицаУченыеСтепени.Ссылка, | ФизическиеЛицаУченыеСтепени.УченаяСтепень, | ФизическиеЛицаУченыеСтепени.ОтрасльНауки, | ФизическиеЛицаУченыеСтепени.ДипломСерияНомер, | ФизическиеЛицаУченыеСтепени.ДатаПрисужденияУченойСтепени |ИЗ | Справочник.ФизическиеЛица.УченыеСтепени КАК ФизическиеЛицаУченыеСтепени |ГДЕ | ФизическиеЛицаУченыеСтепени.Ссылка = &ФизЛицо»; Запрос.УстановитьПараметр(«ФизЛицо», Источник); Выборка = Запрос.Выполнить().Выбрать(); Пока Выборка.Следующий() Цикл Отбор = Новый ТаблицаЗначений; Отбор.Колонки.Добавить («Имя»); Отбор.Колонки.Добавить («Значение»); Отбор.Колонки.Добавить («Использование»); СтрокаОтбора = Отбор.Добавить (); СтрокаОтбора.Имя = «ФизическоеЛицо»; СтрокаОтбора.Значение = Выборка.Ссылка; СтрокаОтбора.Использование = Истина; Строки = Новый ТаблицаЗначений; Строки.Колонки.Добавить(«Ссылка»); Строки.Колонки.Добавить(«ФизическоеЛицо»); Строки.Колонки.Добавить(«УченаяСтепень»); Строки.Колонки.Добавить(«Специальность»); Строки.Колонки.Добавить(«НомерДиплома»); Строки.Колонки.Добавить(«Период»); Строка = Строки.Добавить(); Строка.ФизическоеЛицо = Выборка.Ссылка; Строка.УченаяСтепень = Выборка.УченаяСтепень; Строка.Специальность = Выборка.ОтрасльНауки; Строка.НомерДиплома = Выборка.ДипломСерияНомер; Строка.Период = Выборка.ДатаПрисужденияУченойСтепени; НаборЗаписей = Новый Структура(«Отбор, Строки»); НаборЗаписей.Отбор = Отбор; НаборЗаписей.Строки = Строки; ВыгрузитьРегистр(НаборЗаписей,,,Истина,»УченыеСтепениФизическихЛиц»); КонецЦикла;

Выгрузка Табличная часть -> Документ.

Предположим, в «источнике» информация для переноса хранится в менее детализированном виде, чем в приемнике, но достаточном для переноса. Например, мной решалась задача по переносу информации об образовании физических лиц из ЗиКБУ в Университет. Понятно, что на стороне кадровой программы нужна минимальная информация об образовании физических лиц, главное что сотрудник обладает необходимой квалификацией и хватит. А вот на стороне университета, информация об образовании, а точнее о дипломах хранится куда более подробно, в связи со спецификой учереждения.

И опять задача решается, при помощи все той же функции ВыгрузитьПоПравилу.

Вот пример выгрузки Дипломов физических лиц. Все тот же обработчик «После выгрузки в файл» ПКО «Физические лица», пишем следующий код:

/////////////////////////////////////////////////////// //Выгрузим образование Физического лица Запрос = Новый Запрос; Запрос.Текст = «ВЫБРАТЬ | ФизическиеЛицаОбразование.Ссылка КАК Студент, | ФизическиеЛицаОбразование.ВидОбразования, | ФизическиеЛицаОбразование.УчебноеЗаведение, | ФизическиеЛицаОбразование.Специальность.Наименование КАК Специальность, | ФизическиеЛицаОбразование.Диплом, | ФизическиеЛицаОбразование.ГодОкончания, | ФизическиеЛицаОбразование.Квалификация |ИЗ | Справочник.ФизическиеЛица.Образование КАК ФизическиеЛицаОбразование |ГДЕ | ФизическиеЛицаОбразование.Ссылка = &ФизЛицо»; Запрос.УстановитьПараметр(«ФизЛицо», Источник); РезультатЗапроса = Запрос.Выполнить(); ВыборкаДетальныеЗаписи = РезультатЗапроса.Выбрать(); Пока ВыборкаДетальныеЗаписи.Следующий() Цикл ВходящиеДанные = Новый Структура; ВходящиеДанные.Вставить(«Студент», ВыборкаДетальныеЗаписи.Студент); ВходящиеДанные.Вставить(«ВидОбразования», ВыборкаДетальныеЗаписи.ВидОбразования); ВходящиеДанные.Вставить(«ОбразовательноеУчреждениеПриОкончании», ВыборкаДетальныеЗаписи.УчебноеЗаведение); ВходящиеДанные.Вставить(«Специальность», ВыборкаДетальныеЗаписи.Специальность); СерияНомерДиплома = ВыборкаДетальныеЗаписи.Диплом; СерияДиплома = «»; НомерДиплома = «»; Выполнить(Алгоритмы.ПолучитьСериюИНомер); ВходящиеДанные.Вставить(«СерияДиплома», СерияДиплома); ВходящиеДанные.Вставить(«НомерДиплома», НомерДиплома); Если НЕ ВыборкаДетальныеЗаписи.ГодОкончания = 0 Тогда ВходящиеДанные.Вставить(«ГодЗавершения», Дата(ВыборкаДетальныеЗаписи.ГодОкончания, 1, 1)); ВходящиеДанные.Вставить(«ДатаВыдачи», Дата(ВыборкаДетальныеЗаписи.ГодОкончания, 1, 1)); Иначе ВходящиеДанные.Вставить(«ГодЗавершения», Дата(«00010101»)); ВходящиеДанные.Вставить(«ДатаВыдачи», Дата(«00010101»)); КонецЕсли; ВходящиеДанные.Вставить(«Квалификация», ВыборкаДетальныеЗаписи.Квалификация); ВыгрузитьПоПравилу(,,ВходящиеДанные,,»ДипломИзВходящихДанных»); КонецЦикла;

Тут мы отбираем данные из табличной части и формируем входящие данные для документа на стороне «приемника», после чего при помощи функции ВыгрузитьПоПравилу, передаем входящие данные ПКО ДипломИзВходящихДанных, которое имеет следующий вид:

В общем, как вы понимаете, можно приводить еще много вариаций перегрузок: справочники, документы, регистры. Главное, надо понимать, что не стоит фанатично бросаться на функции ВыгрузитьПоПравилу и ВыгрузитьРегистр.

Замечания по перегрузке.

1. У меня возникли сложности при использовании правил в БСП, в части выгрузки объектов по ссылкам, проблема решилась принудительной установкой параметра ВыгрузитьОбъект в значение Истина, для каждого ПКС ссылочного типа:

2. Надо помнить, что при выгрузке через указанные функции, зачастую отсутствует УникальныйИдентификатор объекта, например, когда объект для выгрузки собирается по частям в виде структуры ВходящихДанных, поэтому поиск по уникальному идентификатору придется отключить.

Подводим итоги. Когда использовать эти функции?

  1. Вам необходимо перегрузить объекты с сильно различной структурой или на стороне «источника» необходимо собирать объекты для выгрузки из разных объектов.
  2. Вам необходимо перегружать объекты с привязкой к выгрузке других объектов.

А что если оптимизировать выше написанное?

Пишу дополнение к статье, после оставленного пользователем TarasovAV комментария. Данный пользователь заметил, что можно оптимизировать выгрузку связанной информации, путем накопления списка тех объектов, информацию о которых надо будет отдельно выгружать, а потом через один запрос отобрать сразу всю информацию.

Описываю алгоритм предложенный вышеуказанным пользователем:

1. В правиле конвертации «После загрузки правил обмена», создается параметр типа ТаблицаЗначений, в который будет накапливаться список объектов, для которых в последующем будет выгружаться информация:

Параметры.Вставить(«СписокФизическихЛиц», Новый ТаблицаЗначений()); Параметры.СписокФизическихЛиц.Колонки.Добавить(«ФизическоеЛицо»);

2. В в обработчике «После выгрузки» ПКО «Физические лица» (именно для них в примерах мы выгружаем контактные данные, образование и т.п.), мы пополняем нашу таблицу значений новым физическим лицом, проверяя перед этим, а не добавлено ли уже это физическое лицо в таблицу:

НайденнаяСтрока = Параметры.СписокФизическихЛиц.Найти(Источник); Если НайденнаяСтрока = Неопределено Тогда НоваяСтрока = Параметры.СписокФизическихЛиц.Добавить(); НоваяСтрока.ФизическоеЛицо = Источник; КонецЕсли;

3. И финальным действием, будет непосредственная выгрузка информации, только уже с отбором по все физическим лицам сразу. Для этого все обработчики, что были приведены выше начиная, необходимо перенести в правило конвертации «После выгрузки данных», запросы же необходимо изменить, чтобы в них проверялось не равенство одному элементу, а вхождение значения реквизита в массив элементов:

Обратите внимание, как изменилась установка параметра запроса и проверка условия в запросе:

//… «| И КонтактнаяИнформация.Объект В &СписокФизЛицо»; Запрос.УстановитьПараметр(«СписокФизЛицо», Параметры.СписокФизическихЛиц.ВыгрузитьКолонку(«ФизическоеЛицо»)); //…

Привожу полный код, исправленных ранее приведенных примеров:

////////////////////////////////////////////////////// //Выгрузим контактную информацию типа Адрес Запрос = Новый Запрос; Запрос.Текст = «ВЫБРАТЬ | КонтактнаяИнформация.Представление, | КонтактнаяИнформация.Вид, | КонтактнаяИнформация.Тип, | КонтактнаяИнформация.Объект |ИЗ | РегистрСведений.КонтактнаяИнформация КАК КонтактнаяИнформация |ГДЕ | КонтактнаяИнформация.Тип = ЗНАЧЕНИЕ(Перечисление.ТипыКонтактнойИнформации.Адрес) | И КонтактнаяИнформация.Вид В (ЗНАЧЕНИЕ(Справочник.ВидыКонтактнойИнформации.ЮрАдресФизЛица), ЗНАЧЕНИЕ(Справочник.ВидыКонтактнойИнформации.ФактАдресФизЛица)) | И КонтактнаяИнформация.Объект В &СписокФизЛицо»; Запрос.УстановитьПараметр(«СписокФизЛицо», Параметры.СписокФизическихЛиц.ВыгрузитьКолонку(«ФизическоеЛицо»)); Выборка = Запрос.Выполнить ().Выбрать (); Пока Выборка.Следующий () Цикл Отбор = Новый ТаблицаЗначений; Отбор.Колонки.Добавить («Имя»); Отбор.Колонки.Добавить («Значение»); Отбор.Колонки.Добавить («Использование»); СтрокаОтбора = Отбор.Добавить (); СтрокаОтбора.Имя = «Объект»; СтрокаОтбора.Значение = Выборка.Объект; СтрокаОтбора.Использование = Истина; Строки = Новый ТаблицаЗначений; Строки.Колонки.Добавить(«Представление»); Строки.Колонки.Добавить(«Вид»); Строки.Колонки.Добавить(«Тип»); Строки.Колонки.Добавить(«Объект»); Строка = Строки.Добавить(); Строка.Представление = Выборка.Представление; Строка.Вид = Выборка.Вид; Строка.Тип = Выборка.Тип; Строка.Объект = Выборка.Объект; НаборЗаписей = Новый Структура(«Отбор, Строки»); НаборЗаписей.Отбор = Отбор; НаборЗаписей.Строки = Строки; ВыгрузитьРегистр(НаборЗаписей,,,,»КонтактнаяИнформация»); КонецЦикла; /////////////////////////////////////////////////////// //Выгрузим образование Физического лица Запрос = Новый Запрос; Запрос.Текст = «ВЫБРАТЬ | ФизическиеЛицаОбразование.Ссылка КАК Студент, | ФизическиеЛицаОбразование.ВидОбразования, | ФизическиеЛицаОбразование.УчебноеЗаведение, | ФизическиеЛицаОбразование.Специальность.Наименование КАК Специальность, | ФизическиеЛицаОбразование.Диплом, | ФизическиеЛицаОбразование.ГодОкончания, | ФизическиеЛицаОбразование.Квалификация |ИЗ | Справочник.ФизическиеЛица.Образование КАК ФизическиеЛицаОбразование |ГДЕ | ФизическиеЛицаОбразование.Ссылка В &СписокФизЛицо»; Запрос.УстановитьПараметр(«СписокФизЛицо», Параметры.СписокФизическихЛиц.ВыгрузитьКолонку(«ФизическоеЛицо»)); РезультатЗапроса = Запрос.Выполнить(); ВыборкаДетальныеЗаписи = РезультатЗапроса.Выбрать(); Пока ВыборкаДетальныеЗаписи.Следующий() Цикл ВходящиеДанные = Новый Структура; ВходящиеДанные.Вставить(«Студент», ВыборкаДетальныеЗаписи.Студент); ВходящиеДанные.Вставить(«ВидОбразования», ВыборкаДетальныеЗаписи.ВидОбразования); ВходящиеДанные.Вставить(«ОбразовательноеУчреждениеПриОкончании», ВыборкаДетальныеЗаписи.УчебноеЗаведение); ВходящиеДанные.Вставить(«Специальность», ВыборкаДетальныеЗаписи.Специальность); СерияНомерДиплома = ВыборкаДетальныеЗаписи.Диплом; СерияДиплома = «»; НомерДиплома = «»; Выполнить(Алгоритмы.ПолучитьСериюИНомер); ВходящиеДанные.Вставить(«СерияДиплома», СерияДиплома); ВходящиеДанные.Вставить(«НомерДиплома», НомерДиплома); Если НЕ ВыборкаДетальныеЗаписи.ГодОкончания = 0 Тогда ВходящиеДанные.Вставить(«ГодЗавершения», Дата(ВыборкаДетальныеЗаписи.ГодОкончания, 1, 1)); ВходящиеДанные.Вставить(«ДатаВыдачи», Дата(ВыборкаДетальныеЗаписи.ГодОкончания, 1, 1)); Иначе ВходящиеДанные.Вставить(«ГодЗавершения», Дата(«00010101»)); ВходящиеДанные.Вставить(«ДатаВыдачи», Дата(«00010101»)); КонецЕсли; ВходящиеДанные.Вставить(«Квалификация», ВыборкаДетальныеЗаписи.Квалификация); ВыгрузитьПоПравилу(,,ВходящиеДанные,,»ДипломИзВходящихДанных»); КонецЦикла; /////////////////////////////////////////////////////// //Выгрузим информацию по ученым степеням Запрос = Новый Запрос; Запрос.Текст = «ВЫБРАТЬ | ФизическиеЛицаУченыеСтепени.Ссылка, | ФизическиеЛицаУченыеСтепени.УченаяСтепень, | ФизическиеЛицаУченыеСтепени.ОтрасльНауки, | ФизическиеЛицаУченыеСтепени.ДипломСерияНомер, | ФизическиеЛицаУченыеСтепени.ДатаПрисужденияУченойСтепени |ИЗ | Справочник.ФизическиеЛица.УченыеСтепени КАК ФизическиеЛицаУченыеСтепени |ГДЕ | ФизическиеЛицаУченыеСтепени.Ссылка В &СписокФизЛицо»; Запрос.УстановитьПараметр(«СписокФизЛицо», Параметры.СписокФизическихЛиц.ВыгрузитьКолонку(«ФизическоеЛицо»)); Выборка = Запрос.Выполнить().Выбрать(); Пока Выборка.Следующий() Цикл Отбор = Новый ТаблицаЗначений; Отбор.Колонки.Добавить («Имя»); Отбор.Колонки.Добавить («Значение»); Отбор.Колонки.Добавить («Использование»); СтрокаОтбора = Отбор.Добавить (); СтрокаОтбора.Имя = «ФизическоеЛицо»; СтрокаОтбора.Значение = Выборка.Ссылка; СтрокаОтбора.Использование = Истина; Строки = Новый ТаблицаЗначений; Строки.Колонки.Добавить(«Ссылка»); Строки.Колонки.Добавить(«ФизическоеЛицо»); Строки.Колонки.Добавить(«УченаяСтепень»); Строки.Колонки.Добавить(«Специальность»); Строки.Колонки.Добавить(«НомерДиплома»); Строки.Колонки.Добавить(«Период»); Строка = Строки.Добавить(); Строка.ФизическоеЛицо = Выборка.Ссылка; Строка.УченаяСтепень = Выборка.УченаяСтепень; Строка.Специальность = Выборка.ОтрасльНауки; Строка.НомерДиплома = Выборка.ДипломСерияНомер; Строка.Период = Выборка.ДатаПрисужденияУченойСтепени; НаборЗаписей = Новый Структура(«Отбор, Строки»); НаборЗаписей.Отбор = Отбор; НаборЗаписей.Строки = Строки; ВыгрузитьРегистр(НаборЗаписей,,,Истина,»УченыеСтепениФизическихЛиц»); КонецЦикла;

Для отправки данных в 1C есть специальное приложение «Работа с 1С». Доступно в разделе левого меню Приложения / Работа с 1С.

Выгрузка в 1С из Subtotal

На появившемся экране приложения выберите период времени за который вы хотите получить данные и нажмите кнопку «Выгрузить данные в виде XML».

Выгрузка данных может занят длительное время, это зависит от количества ваших данных. Готовый файл выгрузке будет доступен для скачивания в таблице ниже. Смотрите на пример на экране:

Загрузка данных в 1С

Обработка «Загрузка данных в 1С» может запускаться как самостоятельно (для этого ее можно открыть в режиме 1С предприятие через меню «Файл» -> «Открыть») так и добавлена в список внешних печатных форм. Для этого в режиме 1С Предприятие нужно перейти по меню «Сервис» -> «Дополнительные отчеты и обработки» -> «Дополнительные внешние обработки».

В открывшемся окне нужно нажать кнопку «Добавить». По нажатию этой кнопки появится новое диалоговое окно «Регистрация внешней обработки».

В нем нужно нажать на кнопку «Заменить файл внешей обработки» и выбрать в окне выбора файла файл ЗагрузкаДанныхв1С.epf. После этого нужно нажать на кнопку «ОК».

Обработка «Загрузка данных 1С» появится в списке внешних обработок. Ее можно будет запускать двойным щелчком по списку внешних обработок («Сервис» -> «Дополнительные отчеты и обработки» -> «Дополнительные внешние обработки»).

Работа с обработкой
1) Перед загрузкой данных рекомендуется сделать резервную копию базы.
2) При первом запуске обработка создает дополнительное свойства «Код внешней базы» в которое записывается код элемента из системы subtotal. После первого запуска обработки необходимо произвести синхронизацию справочника «Организации» 1С со справочником «Партнеры» системы subtotal. Для этого нужно в дополнительное свойство «Код внешней базы» записать код соответствующей организации из системы subtotal. Определить коды можно выполнив загрузку данных, если система не сможет сопоставить справочники организаций, то будет выдано сообщение об ошибке в котором будет приведен код и наименование организации. Этот код необходимо записать в свойство «Код внешней базы».
Дополнительные свойства можно открыть нажав на кнопку в форме справочника.


3) Загрузка данных производится следующим образом: в форме обработки нужно выбрать путь к файлу выгрузки (Адрес файла). Реквизиты Организация, Базовая ставка НДС, Базовая номенклатурная группа используются как значения «по-умолчанию» при загрузке справочников и документов. По кнопке «Загрузить данные» начинается загрузка.


При первоначальной загрузке рекомендуется установить флажки «Искать номенклатуру по наименованию», «Искать номенклатуру по артикулу» и «Искать контрагентов по ИНН».

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

В большинстве случаев процесс переноса данных в 1C программы связан с некоторыми трудностями. Например, нужно перенести данные, предварительно отфильтрованные по какому-то признаку (контрагент, вид оплаты и т. п.). К тому же нередко перенос данных связан с автоматическим формированием документов, например, если перенос базы данных проводится с помощью переноса справочников и документов продажи.

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

Нередко возникает необходимость частого переноса данных между одинаковыми конфигурациями 1С. Например, при использовании нескольких программ учета нужно ежедневно переносить справочники и документы из одной базы в другую. Некогда разработчики 1С попытались реализовать универсальную программу, позволяющую автоматизировать этот нелегкий процесс, однако сегодня программных продуктов 1С на рынке ПО представлен огромный ассортимент, поэтому разработки перешли в локальное русло, реализовав автоматический перенос данных между «подобными» программами.

Основные способы переноса документов в 1С

1С: Конвертация данных

Фирма «1С» предлагает пользователям традиционный механизм для переноса данных, использующий форму 1С: Конвертация данных. Эта программа использует XML формат. С ее помощью пользователь сначала создает файл последовательных правил, в соответствии с которыми и будет производиться дальнейший перенос данных. С использованием данного программного продукта можно оперативно осуществлять обмен данными, как между одинаковыми, так и разными конфигурациями.

Для одинаковых конфигураций процесс занимает максимум 1 час времени, для разных – несколько больше.

Перенос данных с использованием OLE

Если базы располагаются в одном месте, или у пользователя есть доступ к нескольким базам одновременно, то можно для переноса данных открыть одну базу в другой с использованием механизма OLE. Таким образом перенос данных 1С представляет собой фактически вытягивание необходимой информации (документов и справочников) из одной базы в другую, благодаря чему весь процесс занимает минимум времени и исключает возможность появления ошибок.

Недостаток этого метода заключается в весьма узких ограничениях. Чтобы перенос данных этим способом был возможен, необходимо обеспечить доступ из одной базы в другую. Если же речь идет о распределенных базах данных, то осуществить перенос данных этим способом очень сложно.

Перенос данных при помощи механизма OLE занимает 4-7 часов.

Файловый способ

Наиболее распространенным методом переноса данных в 1С является файловый. Причем файл для переноса нужных данных может иметь любой формат: DBF, Excel, Word, но чаще всего специалисты прибегают к использованию формата XML.

Этот метод переноса данных в 1С работает весьма быстро и подходит почти для всех программных решений. Суть метода заключается в следующем алгоритме:

  • выгрузка данных в файл,
  • передача файла на компьютер пользователя,
  • загрузка его в другой базе данных.

Среди всех преимуществ данного метода хотелось бы отметить его универсальность. Для его использования не важно, где находятся пользователи, ведь файл с выгруженными данными имеет небольшой размер, поэтому его можно отправить на другой компьютер посредством электронной почты или передать на съемном носителе.

Недостаток файлового метода переноса данных в 1С 8.2 в том, что для его реализации пользователь должен обладать достаточной квалификацией. Также к значительным недостаткам можно отнести то, что нужно писать алгоритм загрузки и выгрузки данных, т. е две обработки 1с для переноса данных.

Рекомендуем также еще статьи по программам 1С:

  • Порядок обновления программ на платформе 1С: Предприятие 8.2
  • Файлы приложений офиса Microsoft и 1С: Предприятие 8
  • Варианты подключения компьютеров к 1С ИБД

Вы можете получать новые материалы сайта по RSS-каналу или можете подписаться на новости 1С от Информ Актив и получать их еженедельно на Ваш e-mail .

Розница и маркировка: вести учет будет проще

Розница. В Бухгалтерии работает несколько тысяч компаний, которые занимаются розничной торговлей. Некоторые ведут товароучет в системе «1С:Розница»: приходуют товары и формируют отчеты для розничных продаж.

Раньше таким пользователям приходилось заводить эти документы и в Бухгалтерии, вручную делая двойную работу. Теперь они смогут за пять минут переносить документы из «1С:Розница» в наш сервис. Документы можно импортировать за определенный период и выбирать продолжительность периода.

Маркировка. Из-за требований по маркировке многие компании вынуждены перейти с ЕНВД на УСН и вести учет товаров. Если вы планируете работать в товароучетной системе «1С:Розница», а учет вести в Бухгалтерии, вы сможете переносить товарные документы из 1С в несколько кликов.

Как выгрузить данные из «1С:Розница»

Чтобы выгрузить данные:

1. Скачайте архив с обработчиком на ваш компьютер и разархивируйте его.

2. Откройте 1С. Выберите пункт меню «Файл» → «Открыть». Выберите файл TradeExport.epf и нажмите «Открыть».

3. Откроется окно «Выгрузка данных».

4. В открывшемся окне в поле «Каталог и имя файла» нажмите на кнопку «Сохранить». Откроется окно выбора файла. Укажите папку, в которую нужно выгрузить данные, и укажите, как будет называться файл, в котором сохранятся данные. Нажмите «Открыть».

5. В поле «Организация» выберите организацию, данные которой нужно выгрузить.

6. Выберите период для выгрузки и укажите какие документы выгружать: отгрузочные документы (реализации и поступления) и/или отчеты о розничных продажах.

7. Нажмите «Получить выгрузку».

8. В открывшемся окне выберите папку, в которую будут выгружены данные, и укажите, как будет называться файл, в котором сохранятся данные. Нажмите «Открыть».

Начнется выгрузка данных, и файл сохранится в папку, указанную в пункте 8. Теперь данные можно принять в Контур.Бухгалтерию.

Как загрузить товароучетные данные в Бухгалтерию

1. Перейдите в Контур.Бухгалтерию.

2. Нажмите «Реквизиты и настройки» → «Импорт из 1С».

3. На открывшейся странице «Прием данных из 1С» нажмите на кнопку «Выбрать файл» и выберите файл с выгрузкой из 1С.

4. Контур.Бухгалтерия автоматически проверяет, какие данные есть в загружаемом файле. Если в Контур.Бухгалтерии уже есть какие-либо из этих данных, то на странице импорта будут предложены следующие варианты приема данных:

  • Заменить данными из 1С — данные, заполненные в Контур.Бухгалтерии, будут полностью заменены данными из 1С.
  • Дополнить данными из 1С — к данным в Контур.Бухгалтерии добавятся данные из 1С.
  • Оставить без изменений — данные, заполненные в Контур.Бухгалтерии, останутся без изменений.

Обратите внимание на следующее:

  • Если для отгрузочных документов выбрать «Дополнить данными из 1С», то в случае совпадения данные продублируются. Информация о совпадении данных будет указана в журнале ошибок.
  • Если в импортированных отчетах для розничных продаж вместо себестоимости стоят нули — значит не хватает отгрузочных документов. Заведите их в Контур.Бухгалтерии.

Если есть ситуации, на которые следует обратить внимание при выборе того или иного пункта, сервис предупредит вас о последствиях. Здесь же сообщается о невозможности загрузить данные с указанием причин.

5. После выбора нужных пунктов нажмите «Принять данные». Начнется загрузка данных. Длительность загрузки зависит от количества передаваемых данных. Можно продолжить работу в сервисе — загрузка не прервется. Если во время загрузки возникли ошибки, они фиксируется в Журнале ошибок.

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

Добавить комментарий

Ваш адрес email не будет опубликован. Обязательные поля помечены *