Сохранить данные во внешней обработке 1с
В этой статье мы узнаем, что такое обработки в платформе 1С 8.3 и для каких целей они нужны. Научимся создавать обработки в качестве объектов метаданных конфигурации 1С, научимся создавать внешние обработки, создавать формы обработок, добавлять обработки в подсистемы и давать права на обработки пользователям, а также узнаем, как открыть внешнюю обработку в 1С.
В платформе 1С, помимо объектов конфигурации, которые так или иначе связаны ведением учета (например, Справочники – для хранения однотипной информации, Документы – для отображения событий), существует объект, который напрямую не связан с ведением учета, и с помощью которого можно осуществлять различные вспомогательные действия (групповая обработка справочников и документов, загрузка – выгрузка информации и т.д.). Этот объект – Обработка. Обработки могут быть как объекты какой-то конфигурации, а также внешние – в этом случае сама обработка будет храниться где-то на жестком диске, её можно будет открыть в пользовательском клиенте 1С предприятия, и выполнить нужные действия.
Создать обработку 1С
После выполнения этой команды, будет создана пустая обработка, которая появится в дереве метаданных в соответствующей ветке, а также откроется окно менеджера обработки.
Обработка создана, и вы можете с ней работать: задать имя обработки, синоним и т.д.
Создать внешнюю обработку 1С
Или нажать на кнопку «Новый» в меню «Стандартная».
После откроется окно «Выбор вида документа», в котором необходимо выбрать «Внешняя обработка».
Откроется окно менеджера внешней обработки, и вы можете проделать с ней все нужные операции.
После того, как внешняя обработка создана, её желательно сохранить на жестком диске (и делать это периодически во время работы с ней в конфигураторе). Для того, чтобы сохранить внешнюю обработку необходимо или нажать на кнопку «Сохранить» меню «Стандартная».
Или просто нажать сочетание клавиш Ctrl + S.
После этих действий откроется окно, в котором можно выбрать каталог, где будет храниться эта внешняя обработка, а также ввести название файла.
После сохранения, у внешней обработки сверху будет прописан путь к ней.
Замечу, что файлы всех внешних обработок имеют расширение epf.
Добавить внешнюю обработку 1С
Иногда возникают задачи добавить внешнюю обработку в конфигурацию 1С. Чтобы это сделать, необходимо выделить ветку «Обработки» дерева метаданных конфигурации, вызвать контекстное меню и выполнить в нем команду «Вставить внешнюю обработку, отчет…».
В открывшемся окне необходимо выбрать нужную обработку.
После, обработка появится в дереве.
Сохранить обработку 1С в файл
Может возникнуть обратная задача: сохранить обработку из какой-то конфигурации в файл, т.е. сделать внешнюю обработку из простой обработки.
Делается это достаточно просто: нужно выделить обработку в дереве конфигурации, вызвать контекстное меню и выполнить команду «Сохранить как внешнюю обработку, отчет…»
Откроется окно «Сохранить как», в котором нужно выбрать месторасположение обработки, а также, если это необходимо, изменить название.
Подсистема обработки 1С
Обработку, которую мы создали в дереве метаданных можно включить в любую подсистему, тогда у нас появится возможность отобразить её в пользовательском интерфейсе. Для того, чтобы включить обработку в подсистему, необходимо зайти на закладку «Подсистемы» менеджера обработки и поставить флаг напротив нужной подсистемы.
Можно включить в подсистему другим способом. Необходимо выделить нужную обработку, вызвать контекстное меню и выполнить в этом меню команду «Дополнительно».
В правой части рабочего стола откроется окно «Дополнительно», в котором на закладке «Подсистемы» можно привязать эту обработку к нужной подсистеме, установив флаг рядом с подсистемой.
После того, как мы поставим флажки, то обработка включится в состав подсистемы.
Но, если мы попробуем её найти в пользовательском клиенте, то ни чего не найдем. Также, её не будет в командном интерфейсе подсистемы.
Причина этому – отсутствие основной формы обработки.
Основная форма обработки 1С
Для того, чтобы обработка появилась в командном интерфейсе, необходимо создать основную форму обработки.
Для этого, нужно в менеджере обработки перейти на вкладку «Формы», в которой нажать на кнопку «Добавить». После, откроется конструктор формы обработки, в котором можно ввести название новой обработки, её синоним, и самое главное установить флаг «Назначить форму основной».
Если вы нажмете на кнопку «Далее», то можете выбрать какие реквизиты обработки будут включены на форму, а если нажать на кнопку «Готово», то форма будет создана без реквизитов.
После этого, обработка появится в командном интерфейсе подсистемы.
Замечу, что основная форма обработки указана в свойстве обработки «Основная форма», если мы это свойство очистим.
То даже при наличии формы, обработка не будет отображаться в командном интерфейсе подсистемы.
Права на обработку 1С
Чтобы пользователь мог работать с обработкой, ему нужно дать права на неё. Для этого, необходимо у соответствующей роли для обработки установить права Использовать и Просмотр.
Если вы установите только право Использовать, то пользователь не сможет видеть обработку в интерфейсе. Он сможет только обращаться в ней посредством программного кода.
Если Вы внедряете обработку в какую-то типовую конфигурацию, то лучше для этого создать отдельную роль, а не изменять текущую. Тогда у вас будет меньше проблем с обновлением в будущем.
Открыть обработку 1с
И при выполнении команды с именем обработки будет открыта форма обработки.
Я немного изменил управляемую форму обработки, добавив надпись.
Управляемая форма открылась в независимом окне, если мы хотим, чтобы она открылась поверх окон, то нужно у основной формы обработки установить в свойство «Режим открытия окна» или значение «Блокировать весь интерфейс», или значение «Блокировать окно владельца».
После таких настроек, обработка будет открываться по верх окон.
Открыть внешнюю обработку 1С
В окне «Открыть» необходимо найти и выбрать нужную вам обработку.
После выйдет предупреждение безопасности, если вы знаете, что это за обработка, то нажимаете кнопку «Да».
Форма внешней обработки открылась.
Замечу, что в моем случае открылась форма обработки в отдельном окне, потому что, во-первых, я создал основную форму внешней обработки, а во-вторых, установил у основной формы в свойство «Режим открытия окна» значение блокировать окно владельца.
Чтобы пользователь мог открывать внешние обработки, ему необходимо установить право «Интерактивное открытие внешних обработок».
Другие статьи по конфигурированию в 1С:
- Книга посылается на электронную почту в формате PDF. Можно открыть на любом устройстве!
- Научитесь понимать архитектуру 1С;
- Станете писать код на языке 1С;
- Освоите основные приемы программирования;
- Закрепите полученные знания при помощи задачника.
Отличное пособие по разработке в управляемом приложении 1С, как для начинающих разработчиков, так и для опытных программистов.
- Очень доступный и понятный язык изложения
- Книга посылается на электронную почту в формате PDF. Можно открыть на любом устройстве!
- Поймете идеологию управляемого приложения 1С
- Узнаете, как разрабатывать управляемое приложение;
- Научитесь разрабатывать управляемые формы 1С;
- Сможете работать с основными и нужными элементами управляемых форм
- Программирование под управляемым приложением станет понятным
Эти книги, плюс книга по программированию оперативного учета имеются в едином комплекте: комплект книг по разработке в 1С.
Только для читателей моего блога,
промо-код на скидку в 300 рублей на весь комплект: blog
Если Вам понравился этот урок, был полезен или помог решить какую-нибудь проблему, то Вы можете поддержать мой проект, перечислив любую сумму.
можно оплатить вручную:
В этой статье разберем, как работать с сохранением данных на форме в 1С 8.3.
Сохраняемые данные формы 1С
У любой управляемой формы можно настроить сохранение данных реквизитов формы. Это значит, что форма сохранит данные введенные в поля, которые соответствуют реквизитам, при закрытии формы, а при последующем открытии формы информация в этих полях восстановятся автоматически.
Например, у меня на форме обработки имеются поля, данные в которых сохраняются при закрытии формы и восстанавливаются при последующем открытии.
Это поля Контрагент и Цена.
Для того, чтобы на управляемой форме данные из соответствующих реквизитов сохранялись, необходимо выполнить следующие действия.
Первое. У свойства формы «Автоматическое сохранение данных в настройках» установить значение «Использовать».
Второе. После того, как будет установлено значение в свойство, которое упоминали выше, у реквизитов формы появится колонка «Сохранение». Именно в этой колонке и нужно поставить флажки рядом с теми реквизитами, значения которых мы хотим сохранять при закрытии формы.
После этих действий, данные у отмеченных реквизитов будут сохраняться.
Хранилище настроек в 1С
Вышеприведенный способ позволяет сохранять последние данные, с которыми работали на форме. Но, могут возникнуть ситуации, когда нужно будет сохранять какую-то произвольную комбинацию значений реквизитов, а потом восстановить её. Если рассматривать ситуацию выше, то это может быть комбинация контрагента и цены: для одного контрагента одна цена, для другого другая и т.д.
Для того, чтобы такая возможность имелась, необходимо в свойстве «Хранилище данных настроек» управляемой формы установить значение «Использовать список».
А потом, у нужных реквизитов формы следует установить флаг у свойства «Сохраняемые данные».
После таких изменений, у формы в группе Ещё появятся команды «Сохранить параметры» и «Восстановить параметры».
Теперь мы можем сохранить любую комбинацию реквизитов Контрагент – Цена.
И можем восстановить нужную комбинацию в любой момент работы с формой, а не только при открытии.
- Книга посылается на электронную почту в формате PDF. Можно открыть на любом устройстве!
- Научитесь понимать архитектуру 1С;
- Станете писать код на языке 1С;
- Освоите основные приемы программирования;
- Закрепите полученные знания при помощи задачника.
Отличное пособие по разработке в управляемом приложении 1С, как для начинающих разработчиков, так и для опытных программистов.
- Очень доступный и понятный язык изложения
- Книга посылается на электронную почту в формате PDF. Можно открыть на любом устройстве!
- Поймете идеологию управляемого приложения 1С
- Узнаете, как разрабатывать управляемое приложение;
- Научитесь разрабатывать управляемые формы 1С;
- Сможете работать с основными и нужными элементами управляемых форм
- Программирование под управляемым приложением станет понятным
Эти книги, плюс книга по программированию оперативного учета имеются в едином комплекте: комплект книг по разработке в 1С.
Только для читателей моего блога,
промо-код на скидку в 300 рублей на весь комплект: blog
Если Вам понравился этот урок, был полезен или помог решить какую-нибудь проблему, то Вы можете поддержать мой проект, перечислив любую сумму.
можно оплатить вручную:
Доброго всем времени суток!
Подскажите пожалуйста, каково время существования данных Табличной части внешней обработки и стоит ли там сохранять данные аналогично Реквизитам внешней обработки? Конкретизирую ситуацию: имеется внешняя обработка с несколькими Формами и несколькими табличными частями. Хотелось-бы использовать данные Табличной части обработки в нескольких окнах последовательно, т.е. заполнил в одной Форме - получил в другой, вернулся и восстановил значения не из Параметра Владельца а из Табличной части обработки.
Тогда подскажите как с ними работать. Бьюсь который день, но при закрытии окна источника данных Табличная часть обнуляется. Пробовал как с привязкой ТЧ обработки к ТЧ Формы через свойство Данные, так и без нее. Результат один и тот-же. Набираю Таблицу значений (в последнем варианте обработки), выгружаю или перебором в ТЧ обработки, считаю - данные есть. Закрываю окно - данных нет. Как будто ТЧ существует для каждого экземпляра объекта обработки по отдельности, да еще и по ключу уникальности.
(3) а если клиент сервер с мс скл подключенный по шаред мемори?
Функций типа Сохранить(), Записать() и т.д. для ТЧ не существует или я не прав?
+ (3) Нужны данные не в базе 1С - храните во внешней. MSSQL, MYSQL, просто файлы .
Как-же тогда объявить данные ТЧ обработки общими для всех объектов обработки?
Данные нужны только для текущего сеанса работы с обработкой, при следующем открытии они уже не нужны.
(8) ну, есть, например, параметры сеанса. Если нужно прям хранить данные, то Константы, Справочники, Документы, Регистры и т.д.
(9) а как получается так, что у тебя много экземпляров одной обработки?
Несколько форм критично? Может можно в одной форме интерфейс организовать?
(13) так это несколько разных форм одного экземпляра обработки или одна форма нескольких экземпляров обработки? И это ОФ или УФ?
(13) Дак помести ты во временное хранилище, и получай из него в нужной форме
(16) если обычные - проще всего использовать СохранитьЗначение("МояТЗ",ТЗ); и ТЗ = ВосстановитьЗначение("МояТЗ");
Повторю вопрос: Можно-ли сделать данные ТЧ обработки общими для всех объектов обработки в текущем сеансе? Ничего не могу найти по этой проблеме.
Или придется ее передавать как Параметр к Владельцу?
(20) "МояТЗ" - это название по которому потом восстанавливается значение. Может быть любое, главное, чтоб уникальное в пределах сеанса
(23) нет, это просто строка, это имя которое ты даешь сохраняемому значению, чтобы отличать его от других сохраняемых значений
А для чего тогда эти ТЧ в обработках присутствуют, только как шаблон набора колонок и их ТиповЗначений?
(25) для хранения данных в течении жизненного цикла экземпляра обработки
(25) Так вот у меня примерно так и обстоит: из Формы1 я вызываю Форму2, набираю данные в ТЧ4 и хочу их обработать в Форме1, но только не передавая их как Параметр. В Форме1 существует поле со строковым выражением Данных ТЧ4, редактирование этой строки в ручном режиме пока не планирую, но все может быть. Не исключено что пользователь вызовет Форму2 еще раз, для добавления или редактирования текущих записей ТЧ4.
Спасибо всем за помощь, уже час держу Вас на этой теме.
(26) реквизиты обработки не сохраняют значения, это просто что-то типа временных переменных в пределах активности (сеанса) обработки, нужны они чтоб взаимодействовать с пользователем в основном для последующего получения результата (подбора данных, замены, отчета и тп)
(29) "для хранения данных в течении жизненного цикла экземпляра обработки" = "это просто что-то типа временных переменных в пределах активности (сеанса) обработки"
Может при вызове Формы2 я чего-то упускаю, синтаксис таков:
(31) судя по всему ты в ОФ пытаешься применять навыки программирования УФ
(31) В реквизитах обработки - создаешь свою ТЧ.
На формах - создаешь табличные поля, куда в качестве данных указываешь свою ТЧ.
Всё.
Синтаксис:
2й параметр обычно тип структура, 3й- ЭтаФорма, нужно для работы оповещений / событий выбора, привязанных к форме
У форм создаешь два методы оповещения: событие "ЗапросДанных" и событие "РассылкаДанных".
(31) Первый вариант был именно таким, но закрытие Формы2 очищает данные ТЧ4.
(35) А поподробнее? В синтаксис помощнике ничего такого не нахожу.
(38) так это все таки несколько обработок одинаковых открываются или у одной и той же обработки несколько разных форм?
(38) не, это не мед, а соты пасечника пустые из воска, и улей без пчел, а медом с пчелами ты сам заполняешь
(39) Обработка одна, но вызавается из Форм разных документов как по экземпляром так и по видам. (40) Так как мне объявить одну "соту" как "общая" с медом доступным для всех "пчел" одного сеанса. Т.е. я могу зайти в один документ, создать свой набор записей, обработать записи и закрыть. Все данные ТЧ4 мне больше не нужны, сеанс закрыт. Но в пределах сеанса мне данные ТЧ4 нужны в любой Форме этой обработки.
(41) Используй справочник ДополнительныеОтчетыИОбработки. Пихай в него свою обработку. Там в реквизит ХранилищеОбработки помещай нужные данные. При открытии формы бери данные из этого хранилища.
Вот что странно, реквизит обработки хранит Данные во время сеанса, например реквизит "СсылкаНаОбъект". И "ДополнительныеПараметры" тоже, а Табличные части - как прорва.
(42) не в реквизит ХранилищеОбработки ,а в ХранилищеНастроек. Опечатался чутка.
А что мешает автору сделать реквизит с типом ХранилищеЗначений? Или нужна подсказка как туда записать табличную честь (точнее таблицу значений)?
(44) смотри реквизиты формы "Сохранять значения" и "Сохраняемые значения"
(45) А может быть и не опечатались. Не исключено, что у автора справочник называется ВнешниеОбработки, а реквизит - ХранилищеВнешнейОбработки. Намекаю на старые типовые конфигурации на обычных формах (не управляемых).
(46) ДопПараметры служит для приема данных из конфигурации. (48) В свойствах обычной Формы такого параметра нет, Реквизит Формы это и есть реквизит и живет в пределах времени открытия Формы как переменная определенного Типа. (49) Вот из Синтаксис помощника: "Замечание! Не рекомендуется хранить в реквизитах типа ХранилищеЗначения ссылки на другие объекты базы данных." А мне это и надо.
(52) За напоминание этого свойства Формы спасибо, скоро тоже понадобится. Я лишь хотел создать в обработке Реквизит в виде Структуры = ТабличнаяЧасть, данные которой(ого) будут доступны из любого объекта обработки (в т.ч. Формы) в текущем сеансе. При следующем сеансе и открытии этой Формы значение реквизита должно быть пустым.
(29) (30) Вот такая постановка вопроса меня устраивает, но данные ТЧ4 в Форме1, сформированные в подчиненной Форме2, почему-то пропадают. И как обойти (3) я не услышал.
Может много хочу, уж Вы извините.
Тем не менее, всем спасибо за внимание и участие в обсуждении.
(54) В Таблице Принадлежность хранится информация, о том с какими Объектами конфигурации ассоциируется ВнешняяОбработка. Для внешних печатных форм - Вид документа, справочника и т.п. название Печ.формы и формы, которую она замещает и Набор параметров примитивного типа (число, строка, булево и т.д.) Для внешних обработок табличных частей - вообщем вы и Сами все знаете. По моему тут хранить негде. Может какие-то поля этой ТЧ и лишние в моем контексте, но я эту ТЧ в работе уже использую.
(55) Вы склоняетесь к передаче параметров при открытии-закрытии Формы? Жаль что без этого не обойтись. Жаль, что из двух соседних окон я не могу видеть один и тот-же стул))).
(57) получи как (55) и потом открой, в ОФ объект будет один стул
(58) Тоже самое я могу получить через "ОписаниеОповещенияОЗакрытии".
(60) Ты лучше опиши желаемый сценарий работы пользователя. Найдем решение.
(61) Ок.
1) Пользователь открывает Форму1, ТЧ4 (ТабличнаяЧасть Обработки) - пустая, т.к это первое открытие (запуск) Обработки. В Форме1 есть Поле2 - символьное представление ТЧ4, оно владелец вызова Формы2 (тут могут быть Ваши предложения).
2) По кнопке Выбора открываем Форму2, в которой есть ТЧ - визуальное представление ТЧ4.
3) Пользователь заполняет ТЧФормы и одновременно ТЧ4 (уже проверено).
4) Нажимает кнопку "ВернутьЗначения" и сохраняет Данные ТЧ4 обработки. Данными ТЧ4 функция "ПреобразоватьТЧвСтроку" заполняет Поле2 Формы1.
Вот 4 пункт никак не работает, при закрытии Формы2, ТЧ4 очищается. Как я полагаю и (3) Данные в ТЧ4 существуют только пока открыта Форма2. Функции Сохранить(), Записать() данные ТЧ Обработки не существует. А Форма1 не является владельцем данных Формы2. Оторвать ТЧ Формы2 от ТЧ4 Обработки я тоже пытался, результат тотже.
Почему Реквизит "СсылкаНаОбъект" жив до закрытия последнего окна (Формы) обработки, а эти ТабличныеЧасти умирают? Может COVID виноват?)))
(63) Т.е. В Форме1 должна присутствовать не только Строка с форматированными данными, но и ТЧ=ТЧ4?
(65) ТЧ у тебя одна на всю обработку, а на каждой форме - свое табличное поле, каждое из которых привязано к этой единственной ТЧ. Табчасть одна, доступов к ней много, по одному из каждой формы
(66) Строка нужна для визуального представления выбранной информации, так короче отобразить информацию ТЧ4.
Уже пробую на своей обработке.
(62) Это не то, что я просил. Отвлекись от своих текущих попыток.
Опиши, как это выглядит для пользователя. На его языке. Если это печатная форма, то для какого дока. Как пользователь ее использует.
(69) Вы извините, пожалуйста, но все уже решилось. В (31) посте я выложил строку вызова Формы2 и это оказалось решающим моментом, т.е. ошибкой. Данный синтаксис разрывает связь между объектами в текущем сеансе, или создает новый сеанс (не знаю что вернее). Открытие Формы2 через "ПолучитьФорму" все решило. Я никак не мог обратиться к данному методу пока не создал РеквизитФормы с Типом ссылка на свою обработку "ВнешняяОбработка.МояОбработка". Не хватает навыков стратегического мышления построения Обработки, до этого все работало, пока не решил вызывать подчиненную Форму.
Всем БОЛЬШОЕ спасибо. Был рад увидеть столько откликов.
Малышу Джону, отдельное спасибо. Нужно стараться программировать без кода.
Если ни у кого больше нет ко мне вопросов, то тему можно считать закрытой.
Кaк может человек ожидaть, что его мольбaм о снисхождении ответит Тот, кто превыше, когдa сaм он откaзывaет в милосердии тем, кто ниже его? Петр Трубецкой
У управляемой формы реквизиты заведенные как реквизиты формы, при закрытии и открытии ее заново могут сохраняться и восстанавливаться, достаточно только поставить напротив галочку сохранять и в свойствах формы выбрать "АвтоматическоеСохранениеДанныхВНастройках" - Использовать.
Подробнее в этой статье Как сохранять и восстанавливать значения реквизитов на форме? и там же пример для обычных форм.
А что же делать с реквизитами, которые выступают в роли реквизитов объектов ?
у них такой настройки нет нет - напишем:
Открыв обработку и заполним поля закрываем ее, при следующем открытии все поля заполнены из сохраненных настроек:
Похожие FAQ
Как заполнить табличную часть формы программно? 6Нужно по кнопке Заполнить - сформировать данные для заполнения табличных частей и заполнить их. Форма имеет вид: Рядом с кнопкой Записать и закрыть добавлена кнопка Заполнить документ , код ее команды: // Код заполнения ТЧ НаСервере П 17 правил для составления оптимального ЗАПРОСа к данным базы 1С 42
Для формирования и выполнения запросов к таблицам базы данных в платформе 1С используется специальный объект языка программирования Запрос . Создается этот объект вызовом конструкции Новый Запрос . Запрос удобно использовать, когда требуется получ 1C: Enterprise Development Tools 50
И вот случилось долгожданное: Вышел 1C: Enterprise Development Tools - это среда для разработки конфигурации в IDE Eclipse. С сайта 1С: « 1C:Enterprise Development Tools » – это инструмент нового поколения для разработчиков бизнес-приложений систем Google maps : вывод точек на карту и режим панорамы 7
В отличие от яндекс карт в GMaps можно использовать панорамы - за что им большой плюс! Надеюсь в яндексе прочитают этот пост и тоже когда-нибудь это сделают! Для клиента нужно было сделать вывод объектов на карту С возможностью просмотра панора База 1С при запуске уходит в дамп и вылетает 1
В последнее время частенько обращаются пользователи у которых после замены или ремонта компьютера 1С не запускается, а точнее при открытии уходит в dump и вылетает. Как правило, решение одно: Отключить аппаратное ускорение видеокарты В Window Посмотреть все результаты поиска похожих
Еще в этой же категории
Как обновить динамический список или реквизит на форме клиента? 19Если вы, открыв форму справочника или документа, выполнили некоторое действие, код который должен изменить состояние данных в динамических списках или значение реквизита. Данные изменены, но в открытой форме осталось все как было, можно конечно закр Как установить параметр динамического списка? 14
Когда используете для вывода данных динамический список и произвольный запрос, то бывают ситуации когда надо указать параметр используемый в этом запросе. Ниже пример вывода данных регистра сведений в карточке клиента Для вывода используется исп Список НЕ модальных методов в 1С 4
Найдено в интернете но говорят что с диска ИТС. Табличная часть
Читайте также: