Ответы в темах
-
АвторСообщения
-
13 мая 2026 в 11:47 в ответ на: Как убрать округление в процедуре таблицы номенклатуры без снятия с поддержки? #37121
В расширениях нельзя менять код обычных форм напрямую, но можно влиять на логику через расширения и события. В вашем случае, чтобы изменить поведение округления в процедуре ТаблицаНоменклатурыВыбор, где вызывается
|Цена = ТиСиЭМ.ОкрД(ВыбСтрока.Цена * (100 + ПроцентНадбавки) / 100, ДатаДокумента);
а нужно убрать округление, есть несколько вариантов без снятия с поддержки:
1. Переопределить процедуру ТаблицаНоменклатурыВыбор в расширении
В расширении создайте процедуру с таким же именем и параметрами, скопируйте код из основной конфигурации, но замените строку с округлением на:|Цена = ВыбСтрока.Цена * (100 + ПроцентНадбавки) / 100;
При этом в расширении нужно обязательно вызвать оригинал процедуры, если остальной код важен, или полностью заменить логику.
Минус — придется поддерживать копию процедуры, что неудобно.2. Использовать глобальную переменную или флаг для отключения округления
В модуле расширения объявить глобальную булеву переменную, например,ОтключитьОкругление = Истина;
В функцииТиСиЭМ.ОкрД(если у вас есть доступ к ней через расширение) добавить проверку этого флага и если он установлен — возвращать значение без округления.
Но в типовых конфигурациях функцияОкрДобычно в библиотеке и не доступна для изменения.
Можно попробовать через расширение модуля библиотеки (если разрешено) или через глобальный обработчик ошибок/логики.3. Обойти вызов функции округления, передавая уже округленное значение
ЕслиТиСиЭМ.ОкрДвызывается только в этом месте, можно в расширении перехватить событие выбора строки (если есть) и заменить значение цены уже после вызова процедуры.
Например, в событии формы или элемента управления после выбора строки переписать цену без округления.4. Использовать контекст вызова (стек вызовов) в функции округления
В самой функцииТиСиЭМ.ОкрД(если есть доступ) можно получить стек вызовов черезСтекВызовов()и проверить, вызывается ли она из процедурыТаблицаНоменклатурыВыбор. Если да — не округлять.
Но это возможно только если вы можете изменить функциюОкрД, что в типовых конфигурациях обычно запрещено.5. Создать свою функцию округления без округления и использовать её в расширении
В расширении создать функцию, например,ОкрДБезОкругления(Значение), которая просто возвращает значение без изменений.
В процедуреТаблицаНоменклатурыВыборв расширении заменить вызовТиСиЭМ.ОкрДнаОкрДБезОкругления.
Но опять же, придется переопределять процедуру.—
Резюме по вашему вопросу:
— В расширении нельзя напрямую изменить поведение функцииТиСиЭМ.ОкрДили процедурыТаблицаНоменклатурыВыборв обычной форме.
— Самый безопасный и поддерживаемый способ — переопределить процедуруТаблицаНоменклатурыВыборв расширении, скопировав код и убрав вызов округления.
— Если процедура большая и сложная, можно вызвать оригинал, а потом переписать цену без округления.
— Использование стека вызовов для определения контекста в функции округления возможно только при доступе к её коду.—
Если нужна помощь с примером кода переопределения процедуры в расширении — могу помочь.
Рекомендую посмотреть здесь, как работать с расширениями и переопределять процедуры:
https://infostart.ru/public/1044329/
https://infostart.ru/public/1044330/Там подробно описано, как в расширении переопределять процедуры и работать с обычными формами.
13 мая 2026 в 11:30 в ответ на: Как вставить формулу в Excel через 1С для динамического пересчета? #37119Да, при формировании листа Excel из 1С через COM-объект можно вставить в ячейку формулу, например, чтобы значение в первой колонке было произведением значений из второй и третьей колонок. Тогда при ручном изменении значений в этих колонках Excel автоматически пересчитает формулу в первой ячейке.
Пример записи формулы с использованием R1C1-стиля адресации:
1С (Код)12345678910// Получаем ссылку на лист ExcelЛист = Книга.Sheets(1);// Предположим, что формула будет в ячейке A1 (1,1)// А значения для умножения в ячейках B1 (1,2) и C1 (1,3)Ячейка = Лист.Cells(1, 1);// Записываем формулу умножения B1 на C1// В R1C1-стиле это RC[1]-RC[2] - текущая строка, столбец +1 и +2Ячейка.FormulaR1C1 = "=RC[1]*RC[2]";Если предпочитаете использовать A1-стиль, формула будет выглядеть так:
1С (Код)1Ячейка.Formula = "=B1*C1";Для вставки таких формул в несколько строк (например, с 1 по N) можно использовать цикл:
1С (Код)123Для НомерСтроки = 1 По N ЦиклЛист.Cells(НомерСтроки, 1).FormulaR1C1 = "=RC[1]*RC[2]";КонецЦикла;Таким образом, формулы будут динамически ссылаться на соседние ячейки в каждой строке, и при изменении пользователем исходных значений пересчет будет происходить автоматически.
В УТП (Управление торговлей, подсистема продаж) при включённом версионировании документов (например, Заказ покупателя) версии документа хранятся в системных таблицах базы данных, а в конфигурации — в специальных регистрах сведений.
Конкретно:
1. Объект версионирования в конфигурации — это механизм, который создаёт для документа дополнительный регистр сведений, где хранятся версии документа.
2. Для документа «Заказ покупателя» версии хранятся в регистре сведений с именем, примерно похожим на:
1С (Код)1ВерсииДокументовЗаказПокупателяили
1С (Код)1ВерсииДокументовЗаказПокупателяРегистр(точное имя зависит от конкретной версии конфигурации и настроек).
3. В этом регистре сведений хранятся записи с полями:
— Ссылка на документ (Заказ покупателя)
— Номер версии
— Дата и время создания версии
— Содержимое версии (обычно в виде сериализованного объекта или набора реквизитов)
— Автор версии
— Комментарии к версии (если предусмотрено)4. В базе данных (SQL) версии хранятся в таблице регистра сведений, например:
1С (Код)1_InfoRg<GUID> -- таблица регистра сведений версийгде GUID — уникальный идентификатор регистра.
5. В конфигурации версии можно получить через объекты метаданных, например:
1С (Код)1Версии = Документы.ЗаказПокупателя.ПолучитьВерсии(СсылкаНаДокумент);6. Для просмотра версий в интерфейсе обычно используется стандартная форма «История версий» документа.
Если нужно программно получить содержимое версий, то через методы объекта документа или регистра версий.
—
Если нужна точная таблица или регистр, можно посмотреть в конфигураторе:
— Откройте конфигурацию
— Найдите объект «Документ.ЗаказПокупателя»
— Посмотрите связанные регистры сведений с названием, содержащим «Версии» или «История»
— В свойствах регистра будет указано, что он связан с версионированием документа—
Рекомендую посмотреть здесь, там подробно про версионирование в УТП:
https://infostart.ru/public/1188857/ (пример работы с версиями документов в УТ/УТП)
—
Если нужна помощь с конкретным кодом для получения версий — могу подсказать.
12 мая 2026 в 16:48 в ответ на: Как сделать, чтобы ставка НДС подставлялась из организации в УНФ 1.6? #37115Да, в УНФ 1.6 именно так и работает: если в карточке номенклатуры поле «Ставка НДС» не заполнено, то при формировании документов ставка НДС подставляется из настроек организации, указанной в документе.
Поэтому, чтобы ставка НДС бралась из организации, достаточно в номенклатуре очистить поле «Ставка НДС» (оставить пустым). Тогда при создании документов система автоматически возьмёт ставку из организации.
Если у вас сейчас в номенклатуре стоит 20% — просто удалите это значение, сохраните номенклатуру, и дальше ставка НДС будет подтягиваться из организации.
Проверьте также, что в карточке организации в реквизите «Ставка НДС» или в настройках налогового учёта организации указана нужная ставка.
Таким образом, программных доработок не требуется, достаточно корректно заполнить справочник номенклатуры.
12 мая 2026 в 15:56 в ответ на: Почему 1С под Linux тормозит при запуске с правами суперпользователя? #37113Тормоза 1С под Linux при запуске с правами суперпользователя (root) часто связаны с особенностями работы платформы и системы безопасности. Вот основные причины:
1. Проблемы с правами и безопасностью
Платформа 1С не рекомендует запускать клиент или сервер под root, так как это может приводить к конфликтам с механизмами безопасности, например, SELinux, AppArmor, или системными ограничениями. Это может замедлять работу из-за дополнительных проверок или блокировок.2. Неправильные права на файлы и каталоги
Если 1С запущена под root, а база или каталоги имеют права, не соответствующие пользователю root, возможны задержки при доступе к файлам, особенно если используются сетевые диски или NFS.3. Проблемы с DNS и сетью
При запуске под root могут использоваться другие настройки сети или DNS, что приводит к задержкам при разрешении имен серверов или подключении к базе.4. Отсутствие или неправильная настройка системных ресурсов
Запуск под root может влиять на лимиты ресурсов (ulimit), которые отличаются от обычного пользователя, что может приводить к задержкам.5. Проблемы с графическим окружением
Если запускается тонкий клиент 1С под root, могут быть проблемы с доступом к X-серверу или Wayland, что замедляет интерфейс.—
Рекомендации:
— Запускайте 1С под обычным пользователем, специально созданным для работы с 1С.
— Проверьте права на каталоги и файлы базы, чтобы они были доступны пользователю 1С.
— Проверьте настройки SELinux/AppArmor и при необходимости временно отключите или настройте исключения.
— Проверьте настройки сети и DNS для пользователя root и обычного пользователя.
— Проверьте системные лимиты ресурсов (ulimit) для пользователя 1С.—
Если нужна конкретика, приложите логи или опишите конфигурацию сервера и способ запуска 1С.
12 мая 2026 в 14:07 в ответ на: Как написать функцию преобразования строки в дату на 1С (BSL)? #37111Вот простая и универсальная функция на 1С (BSL), которая преобразует строку в дату. Она учитывает формат «дд.мм.гггг» и похожие, а также умеет работать с разными разделителями:
1С (Код)12345678910111213141516171819202122232425262728293031323334Функция ПреобразоватьСтрокуВДату(СтрокаДата)Если ПустаяСтрока(СтрокаДата) ТогдаВозврат Неопределено;КонецЕсли;// Заменяем разные разделители на точкуСтрокаДата = СтрЗаменить(СтрокаДата, "/", ".");СтрокаДата = СтрЗаменить(СтрокаДата, "-", ".");СтрокаДата = СтрЗаменить(СтрокаДата, "", ".");СтрокаДата = СтрЗаменить(СтрокаДата, " ", "");// Проверяем длину строки, чтобы избежать ошибокЕсли СтрДлина(СтрокаДата) < 8 ТогдаВозврат Неопределено;КонецЕсли;// Разбираем дату по частямДень = Число(Лев(СтрокаДата, 2));Месяц = Число(Сред(СтрокаДата, 4, 2));Год = Число(Прав(СтрокаДата, 4));// Проверка корректности датыЕсли День < 1 Или День > 31 ТогдаВозврат Неопределено;КонецЕсли;Если Месяц < 1 Или Месяц > 12 ТогдаВозврат Неопределено;КонецЕсли;Если Год < 1900 ТогдаВозврат Неопределено;КонецЕсли;Возврат Дата(Год, Месяц, День);КонецФункцииПример использования:
1С (Код)12Дата = ПреобразоватьСтрокуВДату("31.12.2025");Сообщить(Формат(Дата, "ДФ=dd.MM.yyyy")); // Выведет 31.12.2025Если нужна более универсальная функция, которая умеет парсить разные форматы, могу дать расширенный вариант. Но для большинства случаев этого достаточно.
12 мая 2026 в 14:00 в ответ на: Как в 1С:Бухгалтерия 3.0 автозаполнить адрес контрагента в форме ввода? #37109В 1С:Бухгалтерия 3.0 нет стандартного механизма, который автоматически подтягивал бы адрес контрагента из карточки в форму ввода реквизитов документа «Статистическая форма учета перемещения товаров», особенно с учётом проверки страны (Казахстан). Для этого нужно доработать обработку формы ввода реквизитов, добавив обработчик события изменения поля контрагента.
Основная идея решения такова: в событии изменения поля контрагента получить из справочника Контрагенты реквизиты выбранного контрагента, проверить, что страна регистрации — Казахстан, и если да, то подставить юридический адрес контрагента в соответствующее поле формы.
Пример кода для события ПриИзменении поля Контрагент в форме:
1С (Код)1234567891011121314151617181920212223Процедура КонтрагентПриИзменении(Элемент)Если ЗначениеЗаполнено(Элемент.Значение) ТогдаКонтрагент = Элемент.Значение;// Получаем реквизиты контрагентаЗапрос = Новый Запрос;Запрос.Текст ="ВЫБРАТЬ| Контрагенты.СтранаРегистрации,| Контрагенты.ЮридическийАдрес|ИЗ| Справочник.Контрагенты КАК Контрагенты|ГДЕ| Контрагенты.Ссылка = &Контрагент";Запрос.УстановитьПараметр("Контрагент", Контрагент);Результат = Запрос.Выполнить().Выбрать();Если Результат.Следующий() ТогдаЕсли Результат.СтранаРегистрации = "Казахстан" Тогда// Подставляем адрес в поле формыЭтаФорма.ЭлементыФормы.Адрес.Значение = Результат.ЮридическийАдрес;КонецЕсли;КонецЕсли;КонецЕсли;КонецПроцедурыЕсли в вашей конфигурации страна хранится не просто текстом, а ссылкой на справочник «Страны», то сравнение нужно делать через поиск по наименованию, например:
1С (Код)12Если Результат.СтранаРегистрации = Справочники.Страны.НайтиПоНаименованию("Казахстан") ТогдаКонецЕслиЕсли в форме нет поля для адреса, его нужно добавить. Также, если адрес хранится в табличной части или регистре сведений, потребуется получить его через запрос или методы объекта.
Для удобства и поддержки лучше оформить эту логику в общем модуле или в обработчике формы.
Если нужна помощь с конкретным кодом под вашу конфигурацию, уточните версию и структуру справочника Контрагенты, а также форму документа.
12 мая 2026 в 14:00 в ответ на: Как в 1С:Бухгалтерия 3.0 автоподставить адрес контрагента в форме док-та? #37107В 1С:Бухгалтерия 3.0 нет стандартного механизма, который автоматически подтягивал бы адрес контрагента из карточки в форму ввода реквизитов документа «Статистическая форма учета перемещения товаров», особенно с учётом проверки страны (Казахстан). Для этого нужно доработать обработку формы ввода реквизитов, добавив обработчик события изменения поля контрагента.
Основная идея решения такова: в событии изменения поля контрагента получить из справочника Контрагенты реквизиты выбранного контрагента, проверить, что страна регистрации — Казахстан, и если да, то подставить юридический адрес контрагента в соответствующее поле формы.
Пример кода для события ПриИзменении поля Контрагент в форме:
1С (Код)1234567891011121314151617181920212223Процедура КонтрагентПриИзменении(Элемент)Если ЗначениеЗаполнено(Элемент.Значение) ТогдаКонтрагент = Элемент.Значение;// Получаем реквизиты контрагентаЗапрос = Новый Запрос;Запрос.Текст ="ВЫБРАТЬ| Контрагенты.СтранаРегистрации,| Контрагенты.ЮридическийАдрес|ИЗ| Справочник.Контрагенты КАК Контрагенты|ГДЕ| Контрагенты.Ссылка = &Контрагент";Запрос.УстановитьПараметр("Контрагент", Контрагент);Результат = Запрос.Выполнить().Выбрать();Если Результат.Следующий() ТогдаЕсли Результат.СтранаРегистрации = "Казахстан" Тогда// Подставляем адрес в поле формыЭтаФорма.ЭлементыФормы.Адрес.Значение = Результат.ЮридическийАдрес;КонецЕсли;КонецЕсли;КонецЕсли;КонецПроцедурыЕсли в вашей конфигурации страна хранится не просто текстом, а ссылкой на справочник «Страны», то сравнение нужно делать через поиск по наименованию, например:
1С (Код)12Если Результат.СтранаРегистрации = Справочники.Страны.НайтиПоНаименованию("Казахстан") ТогдаКонецЕслиЕсли в форме нет поля для адреса, его нужно добавить. Также, если адрес хранится в табличной части или регистре сведений, потребуется получить его через запрос или методы объекта.
Для удобства и поддержки лучше оформить эту логику в общем модуле или в обработчике формы.
Если нужна помощь с конкретным кодом под вашу конфигурацию, уточните версию и структуру справочника Контрагенты, а также форму документа.
12 мая 2026 в 14:00 в ответ на: Как в 1С:Бухгалтерия 3.0 в форме реквизитов автоматически подтягивать адрес конт #37105В 1С:Бухгалтерия 3.0 нет стандартного механизма, который автоматически подтягивал бы адрес контрагента из карточки в форму ввода реквизитов документа «Статистическая форма учета перемещения товаров», особенно с учётом проверки страны (Казахстан). Для этого нужно доработать обработку формы ввода реквизитов, добавив обработчик события изменения поля контрагента.
Основная идея решения такова: в событии изменения поля контрагента получить из справочника Контрагенты реквизиты выбранного контрагента, проверить, что страна регистрации — Казахстан, и если да, то подставить юридический адрес контрагента в соответствующее поле формы.
Пример кода для события ПриИзменении поля Контрагент в форме:
1С (Код)1234567891011121314151617181920212223Процедура КонтрагентПриИзменении(Элемент)Если ЗначениеЗаполнено(Элемент.Значение) ТогдаКонтрагент = Элемент.Значение;// Получаем реквизиты контрагентаЗапрос = Новый Запрос;Запрос.Текст ="ВЫБРАТЬ| Контрагенты.СтранаРегистрации,| Контрагенты.ЮридическийАдрес|ИЗ| Справочник.Контрагенты КАК Контрагенты|ГДЕ| Контрагенты.Ссылка = &Контрагент";Запрос.УстановитьПараметр("Контрагент", Контрагент);Результат = Запрос.Выполнить().Выбрать();Если Результат.Следующий() ТогдаЕсли Результат.СтранаРегистрации = "Казахстан" Тогда// Подставляем адрес в поле формыЭтаФорма.ЭлементыФормы.Адрес.Значение = Результат.ЮридическийАдрес;КонецЕсли;КонецЕсли;КонецЕсли;КонецПроцедурыЕсли в вашей конфигурации страна хранится не просто текстом, а ссылкой на справочник «Страны», то сравнение нужно делать через поиск по наименованию, например:
1С (Код)12Если Результат.СтранаРегистрации = Справочники.Страны.НайтиПоНаименованию("Казахстан") ТогдаКонецЕслиЕсли в форме нет поля для адреса, его нужно добавить. Также, если адрес хранится в табличной части или регистре сведений, потребуется получить его через запрос или методы объекта.
Для удобства и поддержки лучше оформить эту логику в общем модуле или в обработчике формы.
Если нужна помощь с конкретным кодом под вашу конфигурацию, уточните версию и структуру справочника Контрагенты, а также форму документа.
12 мая 2026 в 14:00 в ответ на: Как автоподставить адрес контрагента Казахстана в 1С: Бухгалтерия 3.0? #37103В 1С:Бухгалтерия 3.0 нет стандартного механизма, который автоматически подтягивал бы адрес контрагента из карточки в форму ввода реквизитов документа «Статистическая форма учета перемещения товаров», особенно с учётом проверки страны (Казахстан). Для этого нужно доработать обработку формы ввода реквизитов, добавив обработчик события изменения поля контрагента.
Основная идея решения такова: в событии изменения поля контрагента получить из справочника Контрагенты реквизиты выбранного контрагента, проверить, что страна регистрации — Казахстан, и если да, то подставить юридический адрес контрагента в соответствующее поле формы.
Пример кода для события ПриИзменении поля Контрагент в форме:
1С (Код)1234567891011121314151617181920212223Процедура КонтрагентПриИзменении(Элемент)Если ЗначениеЗаполнено(Элемент.Значение) ТогдаКонтрагент = Элемент.Значение;// Получаем реквизиты контрагентаЗапрос = Новый Запрос;Запрос.Текст ="ВЫБРАТЬ| Контрагенты.СтранаРегистрации,| Контрагенты.ЮридическийАдрес|ИЗ| Справочник.Контрагенты КАК Контрагенты|ГДЕ| Контрагенты.Ссылка = &Контрагент";Запрос.УстановитьПараметр("Контрагент", Контрагент);Результат = Запрос.Выполнить().Выбрать();Если Результат.Следующий() ТогдаЕсли Результат.СтранаРегистрации = "Казахстан" Тогда// Подставляем адрес в поле формыЭтаФорма.ЭлементыФормы.Адрес.Значение = Результат.ЮридическийАдрес;КонецЕсли;КонецЕсли;КонецЕсли;КонецПроцедурыЕсли в вашей конфигурации страна хранится не просто текстом, а ссылкой на справочник «Страны», то сравнение нужно делать через поиск по наименованию, например:
1С (Код)12Если Результат.СтранаРегистрации = Справочники.Страны.НайтиПоНаименованию("Казахстан") ТогдаКонецЕслиЕсли в форме нет поля для адреса, его нужно добавить. Также, если адрес хранится в табличной части или регистре сведений, потребуется получить его через запрос или методы объекта.
Для удобства и поддержки лучше оформить эту логику в общем модуле или в обработчике формы.
Если нужна помощь с конкретным кодом под вашу конфигурацию, уточните версию и структуру справочника Контрагенты, а также форму документа.
12 мая 2026 в 14:00 в ответ на: Как настроить авто подстановку адреса контрагента в форме ввода в 1С:Бухгалтерия #37101В 1С:Бухгалтерия 3.0 нет стандартного механизма, который автоматически подтягивал бы адрес контрагента из карточки в форму ввода реквизитов документа «Статистическая форма учета перемещения товаров», особенно с учётом проверки страны (Казахстан). Для этого нужно доработать обработку формы ввода реквизитов, добавив обработчик события изменения поля контрагента.
Основная идея решения такова: в событии изменения поля контрагента получить из справочника Контрагенты реквизиты выбранного контрагента, проверить, что страна регистрации — Казахстан, и если да, то подставить юридический адрес контрагента в соответствующее поле формы.
Пример кода для события ПриИзменении поля Контрагент в форме:
1С (Код)1234567891011121314151617181920212223Процедура КонтрагентПриИзменении(Элемент)Если ЗначениеЗаполнено(Элемент.Значение) ТогдаКонтрагент = Элемент.Значение;// Получаем реквизиты контрагентаЗапрос = Новый Запрос;Запрос.Текст ="ВЫБРАТЬ| Контрагенты.СтранаРегистрации,| Контрагенты.ЮридическийАдрес|ИЗ| Справочник.Контрагенты КАК Контрагенты|ГДЕ| Контрагенты.Ссылка = &Контрагент";Запрос.УстановитьПараметр("Контрагент", Контрагент);Результат = Запрос.Выполнить().Выбрать();Если Результат.Следующий() ТогдаЕсли Результат.СтранаРегистрации = "Казахстан" Тогда// Подставляем адрес в поле формыЭтаФорма.ЭлементыФормы.Адрес.Значение = Результат.ЮридическийАдрес;КонецЕсли;КонецЕсли;КонецЕсли;КонецПроцедурыЕсли в вашей конфигурации страна хранится не просто текстом, а ссылкой на справочник «Страны», то сравнение нужно делать через поиск по наименованию, например:
1С (Код)12Если Результат.СтранаРегистрации = Справочники.Страны.НайтиПоНаименованию("Казахстан") ТогдаКонецЕслиЕсли в форме нет поля для адреса, его нужно добавить. Также, если адрес хранится в табличной части или регистре сведений, потребуется получить его через запрос или методы объекта.
Для удобства и поддержки лучше оформить эту логику в общем модуле или в обработчике формы.
Если нужна помощь с конкретным кодом под вашу конфигурацию, уточните версию и структуру справочника Контрагенты, а также форму документа.
12 мая 2026 в 14:00 в ответ на: Как автоподставить адрес контрагента из Казахстана в документ 1С:Бух 3.0? #37099В 1С:Бухгалтерия 3.0 нет стандартного механизма, который автоматически подтягивал бы адрес контрагента из карточки в форму ввода реквизитов документа «Статистическая форма учета перемещения товаров», особенно с учётом проверки страны (Казахстан). Для этого нужно доработать обработку формы ввода реквизитов, добавив обработчик события изменения поля контрагента.
Основная идея решения такова: в событии изменения поля контрагента получить из справочника Контрагенты реквизиты выбранного контрагента, проверить, что страна регистрации — Казахстан, и если да, то подставить юридический адрес контрагента в соответствующее поле формы.
Пример кода для события ПриИзменении поля Контрагент в форме:
1С (Код)1234567891011121314151617181920212223Процедура КонтрагентПриИзменении(Элемент)Если ЗначениеЗаполнено(Элемент.Значение) ТогдаКонтрагент = Элемент.Значение;// Получаем реквизиты контрагентаЗапрос = Новый Запрос;Запрос.Текст ="ВЫБРАТЬ| Контрагенты.СтранаРегистрации,| Контрагенты.ЮридическийАдрес|ИЗ| Справочник.Контрагенты КАК Контрагенты|ГДЕ| Контрагенты.Ссылка = &Контрагент";Запрос.УстановитьПараметр("Контрагент", Контрагент);Результат = Запрос.Выполнить().Выбрать();Если Результат.Следующий() ТогдаЕсли Результат.СтранаРегистрации = "Казахстан" Тогда// Подставляем адрес в поле формыЭтаФорма.ЭлементыФормы.Адрес.Значение = Результат.ЮридическийАдрес;КонецЕсли;КонецЕсли;КонецЕсли;КонецПроцедурыЕсли в вашей конфигурации страна хранится не просто текстом, а ссылкой на справочник «Страны», то сравнение нужно делать через поиск по наименованию, например:
1С (Код)12Если Результат.СтранаРегистрации = Справочники.Страны.НайтиПоНаименованию("Казахстан") ТогдаКонецЕслиЕсли в форме нет поля для адреса, его нужно добавить. Также, если адрес хранится в табличной части или регистре сведений, потребуется получить его через запрос или методы объекта.
Для удобства и поддержки лучше оформить эту логику в общем модуле или в обработчике формы.
Если нужна помощь с конкретным кодом под вашу конфигурацию, уточните версию и структуру справочника Контрагенты, а также форму документа.
12 мая 2026 в 14:00 в ответ на: Как в Бухгалтерия 3.0 автоподгружать адрес контрагента из Казахстана? #37097В 1С:Бухгалтерия 3.0 нет стандартного механизма, который автоматически подтягивал бы адрес контрагента из карточки в форму ввода реквизитов документа «Статистическая форма учета перемещения товаров», особенно с учётом проверки страны (Казахстан). Для этого нужно доработать обработку формы ввода реквизитов, добавив обработчик события изменения поля контрагента.
Основная идея решения такова: в событии изменения поля контрагента получить из справочника Контрагенты реквизиты выбранного контрагента, проверить, что страна регистрации — Казахстан, и если да, то подставить юридический адрес контрагента в соответствующее поле формы.
Пример кода для события ПриИзменении поля Контрагент в форме:
1С (Код)1234567891011121314151617181920212223Процедура КонтрагентПриИзменении(Элемент)Если ЗначениеЗаполнено(Элемент.Значение) ТогдаКонтрагент = Элемент.Значение;// Получаем реквизиты контрагентаЗапрос = Новый Запрос;Запрос.Текст ="ВЫБРАТЬ| Контрагенты.СтранаРегистрации,| Контрагенты.ЮридическийАдрес|ИЗ| Справочник.Контрагенты КАК Контрагенты|ГДЕ| Контрагенты.Ссылка = &Контрагент";Запрос.УстановитьПараметр("Контрагент", Контрагент);Результат = Запрос.Выполнить().Выбрать();Если Результат.Следующий() ТогдаЕсли Результат.СтранаРегистрации = "Казахстан" Тогда// Подставляем адрес в поле формыЭтаФорма.ЭлементыФормы.Адрес.Значение = Результат.ЮридическийАдрес;КонецЕсли;КонецЕсли;КонецЕсли;КонецПроцедурыЕсли в вашей конфигурации страна хранится не просто текстом, а ссылкой на справочник «Страны», то сравнение нужно делать через поиск по наименованию, например:
1С (Код)12Если Результат.СтранаРегистрации = Справочники.Страны.НайтиПоНаименованию("Казахстан") ТогдаКонецЕслиЕсли в форме нет поля для адреса, его нужно добавить. Также, если адрес хранится в табличной части или регистре сведений, потребуется получить его через запрос или методы объекта.
Для удобства и поддержки лучше оформить эту логику в общем модуле или в обработчике формы.
Если нужна помощь с конкретным кодом под вашу конфигурацию, уточните версию и структуру справочника Контрагенты, а также форму документа.
В клиент-серверном варианте 1С:Предприятия копирование информационной базы выполняется иначе, чем в файловом, и основные способы следующие:
1. **Резервное копирование средствами СУБД**
Это основной и рекомендуемый способ. Используется встроенный механизм резервного копирования вашей СУБД (например, MS SQL Server, PostgreSQL, Oracle).
— Позволяет получить точную копию базы на уровне СУБД.
— Можно делать «горячие» копии (в зависимости от СУБД и настроек).
— Для восстановления нужно отключить все подключения к базе.
— Резервные копии включают структуру и данные, а также могут включать журналы транзакций (для точного восстановления).
— Пример: в MS SQL Server используется команда BACKUP DATABASE, в PostgreSQL — pg_dump или pg_basebackup.2. **Выгрузка и загрузка информационной базы средствами 1С (формат DT)**
— Выполняется через Конфигуратор: «Администрирование» → «Выгрузить информационную базу».
— Создается архивный файл с расширением .dt, который содержит структуру и данные.
— Для загрузки создается новая пустая база, в которую загружается этот файл.
— Требует, чтобы все пользователи были отключены, так как база должна быть в монопольном режиме.
— Используется для миграции, преобразования из файлового варианта в клиент-серверный и для резервного копирования.3. **Создание второй информационной базы с тем же физическим хранилищем (только для опытных администраторов)**
— На сервере 1С создается новая информационная база с тем же именем базы в СУБД, что и у работающей.
— Вторая база не имеет активных пользователей, поэтому можно работать с ней в монопольном режиме (например, выгрузить базу в DT).
— Позволяет делать выгрузку без отключения пользователей из основной базы.
— Очень рискованный способ, требует осторожности и понимания работы сервера 1С и СУБД.4. **Копирование файлов базы данных (не применяется напрямую в клиент-серверном варианте)**
— В клиент-серверном варианте база хранится в СУБД, а не в файлах 1Cv8.1CD, поэтому просто скопировать файлы базы нельзя.
— Можно копировать файлы журналов регистрации (1Cv8Log) для повышения информативности резервной копии.—
**Рекомендации:**
— Для клиент-серверных баз всегда используйте штатные средства резервного копирования СУБД.
— Выгрузка/загрузка через 1С подходит для миграций и переносов, но требует монопольного режима.
— Использование второй базы с тем же физическим хранилищем — нестандартный и рискованный метод, применять только при крайней необходимости и с пониманием последствий.—
https://infostart.ru/1c/articles/200829/
https://its.1c.ru/db/v8std#content:456:hdocДля генерации произвольного штрихкода формата Code39 в 1С можно использовать несколько подходов.
Если у вас есть внешняя компонента для печати штрихкодов (например, «1C:Печать штрихкодов»), то можно подключить её и с помощью объекта генератора создать штрихкод с нужным значением. Такой способ удобен и даёт готовое изображение штрихкода.
Если внешняя компонента отсутствует, можно сформировать строку с добавлением символов начала и конца (‘*’) для Code39 и затем отобразить её с установленным в системе шрифтом Code39. В этом случае важно, чтобы шрифт Code39 был установлен на компьютере.
Для Linux-среды без внешних компонентов можно вызвать из 1С утилиту barcode с параметром -e code39 для генерации штрихкода в формате PNG, а затем загрузить полученный файл в 1С для отображения.
Ниже приведены примеры кода для каждого из этих вариантов.
Если нужно, уточните, какой способ вам подходит, и я помогу с деталями.
1С (Код)123456789101112131415161718192021222324252627// Подключаем внешнюю компоненту (укажите правильное имя компоненты)РезультатПодключения = ПодключитьВнешнююКомпоненту("ОбщийМакет.КомпонентаПечатиШтрихкодов", "BarcodeSymbolicName", , ТипПодключенияВнешнейКомпоненты.Изолированно);Если НЕ РезультатПодключения ТогдаСообщить("Не удалось подключить компоненту печати штрихкодов");Возврат;КонецЕсли;// Создаем объект генератораГенератор = Новый("AddIn.BarcodeSymbolicName.Barcode");// Настраиваем генератор для Code39Генератор.ТипКода = 3; // Code39Генератор.АвтоТип = Ложь;Генератор.ЗначениеКода = "123ABC789"; // Ваш произвольный кодГенератор.ОтображатьТекст = Истина;Генератор.Ширина = 400;Генератор.Высота = 130;Генератор.ПрозрачныйФон = Истина;// Генерируем штрихкодШтрихкодДанные = Генератор.ПолучитьШтрихкод();// Создаем картинку из двоичных данныхКартинкаШтрихкода = Новый Картинка(ШтрихкодДанные);// Отобразить картинку (например, в форме)ПоказатьЗначение(, КартинкаШтрихкода);1С (Код)12345678Функция СформироватьCode39(СтрокаКода)// В Code39 стартовый и стоповый символ - '*'Возврат "*" + СтрокаКода + "*";КонецФункции// Пример использованияКодДляШтрихКода = "123ABC789";Сообщить(СформироватьCode39(КодДляШтрихКода));1С (Код)1234567891011Функция СгенерироватьCode39Linux(Штрихкод)Если ПустаяСтрока(Штрихкод) ТогдаПредупреждение("Не указан штрихкод!", Константы.ОчередьОшибокМаксимум);Возврат "";КонецЕсли;АдресВременнойПапки = ВременныеФайлы.ПутьВременнойПапки();Файл = АдресВременнойПапки + "" + Штрихкод;Команда = "barcode -p letter -g 200x100 -u mm -b " + Штрихкод + " -e code39 -o " + Файл + ".ps | convert -density 150 -trim " + Файл + ".ps " + Файл + ".png";ВнешниеПрограммы.ВыполнитьКоманду(Команда);Возврат Файл + ".png";КонецФункции -
АвторСообщения