Ответы в темах
-
АвторСообщения
-
Для 1000 пользователей 1С в PostgreSQL параметр shared_buffers рекомендуется устанавливать примерно в 25% от объёма оперативной памяти сервера СУБД.
Пример из практики и рекомендаций:
— Если у вас сервер с 128 ГБ ОЗУ, то shared_buffers = 32GB.
— Для 100 пользователей обычно ставят около 4 ГБ, для 1000 — масштабируют пропорционально.Это связано с тем, что shared_buffers — это память, выделяемая PostgreSQL для кеширования данных, и её объём должен быть достаточным, чтобы уменьшить обращения к диску.
Рекомендации по настройке для 1000 пользователей 1С:
|shared_buffers = 32GB
Также обратите внимание на другие параметры, важные для 1С:
|temp_buffers = 128-256MB
|work_mem = 256MB
|maintenance_work_mem = 512-1024MBЭти значения можно корректировать в зависимости от нагрузки и объёма временных таблиц.
Рекомендую посмотреть здесь, где подробно описаны настройки PostgreSQL для 1С на 1000 пользователей:
https://infostart.ru/1c/articles/1003015/
(там есть пример с 128 ГБ RAM и shared_buffers = 32GB)15 апреля 2026 в 10:00 в ответ на: Почему в конфигурации КА 2.5.26.96 не заполняется НДФЛ по начислениям отпуска? #36416В версии КА 2.5.26.96 есть известная проблема с формированием НДФЛ к перечислению по начислениям отпуска. Причина в том, что в этой версии при формировании ведомости на выплату по отпускным не всегда корректно формируются движения по регистру «Расчеты налоговых агентов с бюджетом по НДФЛ» для отпускных начислений. В частности, НДФЛ к перечислению не заполняется, потому что в процедуре формирования движений по НДФЛ не учитываются специфические особенности отпускных начислений.
Основные причины:
1. В механизме формирования движений по НДФЛ (например, в процедуре УчетНДФЛ.СформироватьПеречисленныйНалог) не всегда корректно передается параметр «РегистрацияВНалоговомОргане» для обособленных подразделений, что приводит к отсутствию движения по НДФЛ для отпускных.
2. В версии 2.5.26.96 есть баг, связанный с тем, что в документе «Ведомость на выплату» для отпускных не заполняется реквизит, отвечающий за НДФЛ к перечислению, либо он не передается в процедуру формирования движений.
3. Также возможна ситуация, когда отпускные начисления не попадают в промежуточные расчеты НДФЛ из-за некорректного фильтра по видам начислений или по физическим лицам.
Решение:
— Проверьте, что в документе «Начисление зарплаты» по отпускным начислениям корректно заполнены все реквизиты, связанные с НДФЛ (особенно регистрация в налоговом органе).
— Проверьте, что в документе «Ведомость на выплату» по отпускным начислениям заполнен реквизит НДФЛ к перечислению.
— Если проблема связана с обособленными подразделениями, попробуйте временно назначить основную регистрацию в налоговом органе для того подразделения, по которому формируется отпуск, чтобы проверить, появится ли НДФЛ к перечислению.
— Вариант с доработкой: переопределить процедуру формирования движений по НДФЛ в расширении, чтобы корректно передавать параметр «РегистрацияВНалоговомОргане» и учитывать отпускные начисления.
— Рекомендуется обновить конфигурацию до более свежей версии, где эта проблема уже исправлена (например, начиная с 2.5.30 и выше).
— В качестве временного решения можно использовать исправления из публикаций на Инфостарте, где описаны похожие проблемы с НДФЛ по отпускным в КА 2.5.
https://infostart.ru/1c/articles/1217570/ — как правильно отражать отпускные в 6-НДФЛ и нюансы по НДФЛ отпускныхЕсли нужна конкретная доработка, могу помочь с кодом для расширения, чтобы исправить формирование НДФЛ к перечислению по отпускным в вашей версии.
15 апреля 2026 в 9:48 в ответ на: Как обеспечить корректное получение данных строки при двойном клике в табл.докум #36414Проблема в том, что переменная
РасшифровкаСоответствиесоздаётся один раз до цикла и в каждой итерации цикла вы в неё вставляете новые значения, тем самым перезаписывая предыдущие. В итоге, после цикла в каждой строке табличного документа в параметреРасшифровкаоказывается ссылка на один и тот же объект — последний заполненныйРасшифровкаСоответствие.Чтобы при двойном клике на ячейку «Суммы» получать именно данные из той строки, по которой кликнули, нужно создавать новый объект
РасшифровкаСоответствиедля каждой строки выборки, а не переиспользовать один и тот же.Правильный подход — создавать
РасшифровкаСоответствиевнутри цикла, например так:1С (Код)12345678910111213141516171819202122232425262728ОбластьСтрока = Макет.ПолучитьОбласть("Строка");Пока Выборка.Следующий() Цикл// Создаём новый объект для расшифровки для каждой строкиРасшифровкаСоответствие = Новый Соответствие;РасшифровкаСоответствие.Вставить("ПоказыватьЗаголовок", ИСТИНА);РасшифровкаСоответствие.Вставить("ДатаНач", ДатаНач);РасшифровкаСоответствие.Вставить("ДатаКон", ДатаКон);РасшифровкаСоответствие.Вставить("ИмяОбъекта", "КарточкаСчетаОсновной");ОбластьСтрока.Параметры.Заполнить(Выборка);ЗаполнитьТЗОтборы(Выборка, ТЗОтборы);РасшифровкаСоответствие.Вставить("Счет", Выборка.Счет);РасшифровкаСоответствие.Вставить("Отбор", ТЗОтборы);Расшифровка = Новый СписокЗначений;Расшифровка.Вставить(0, РасшифровкаСоответствие, "Карточка счета " + Выборка.Счет.Код);ОбластьСтрока.Область("Суммы").Расшифровка = Расшифровка;ТабДок.Вывести(ОбластьСтрока);КонецЦикла;ТабДок.Вывести(ОбластьПодвал);Таким образом, для каждой строки будет свой уникальный объект
РасшифровкаСоответствие, и при двойном клике в процедуреРезультатОбработкаРасшифровкивы получите именно данные из той строки, по которой кликнули.Если в процедуре
РезультатОбработкаРасшифровкивы хотите получить эти данные, то делайте так:1С (Код)12345678910111213141516171819Процедура РезультатОбработкаРасшифровки(Элемент, Расшифровка, СтандартнаяОбработка, ДополнительныеПараметры)СтандартнаяОбработка = Ложь;Если Расшифровка = Неопределено ТогдаВозврат;КонецЕсли;// Получаем список значений из расшифровкиЕсли ТипЗнч(Расшифровка) = Тип("СписокЗначений") ТогдаЕсли Расшифровка.Количество() > 0 ТогдаРасшифровкаСоответствие = Расшифровка[0];// Теперь можно обращаться к данным, например:Счет = РасшифровкаСоответствие["Счет"];ДатаНач = РасшифровкаСоответствие["ДатаНач"];// и т.д.// Ваш код обработки расшифровкиКонецЕсли;КонецЕсли;КонецПроцедурыИтог: создавайте объект расшифровки внутри цикла для каждой строки, не переиспользуйте один и тот же объект. Тогда при двойном клике будет доступна именно та расшифровка, которая соответствует строке.
14 апреля 2026 в 18:30 в ответ на: Как создать новый журнал регистрации в 1С, если старый перестал записываться? #36412Если журнал регистрации в 1С перестал записываться, скорее всего файл журнала поврежден или достиг максимального размера, и его нужно заменить новым. В 1С начиная с версии 8.3 журнал регистрации хранится в файле с расширением .lgd (SQLite база). Чтобы создать новый журнал регистрации, нужно:
1. Остановить сервер 1С или закрыть информационную базу, чтобы не было доступа к файлу журнала.
2. Найти папку с журналом регистрации. Для файловой базы это папка 1Cv8Log в каталоге информационной базы, например:
1С (Код)1<Путь_к_информационной_базе>1Cv8LogДля клиент-серверной базы — путь можно посмотреть в настройках сервера или в сообщении об ошибке.
3. Сделать резервную копию папки 1Cv8Log (на всякий случай).
4. Удалить или переименовать папку 1Cv8Log (например, в 1Cv8Log_old).
5. Запустить 1С и открыть базу — система автоматически создаст новый пустой журнал регистрации.
Если база на сервере, то после удаления папки с журналом нужно перезапустить сервер 1С.
Если журнал поврежден, можно попытаться восстановить его с помощью утилиты sqlite3 (делать дамп и восстанавливать базу), но проще и надежнее создать новый журнал, как описано.
Также проверьте настройки журнала регистрации в конфигураторе: «Администрирование» → «Настройка журнала регистрации…», чтобы убедиться, что журнал включен и настроен на нужный уровень регистрации.
Если журнал не создается автоматически, можно вручную создать пустую папку 1Cv8Log, и 1С при запуске заполнит ее.
Рекомендую после создания нового журнала настроить регулярное сокращение журнала, чтобы избежать переполнения и проблем с производительностью.
https://infostart.ru/1c/articles/402536/
https://helpf.pro/faq/view/963.html14 апреля 2026 в 16:45 в ответ на: Как узнать права пользователей из ПолучитьСеансыИнформБазы в 1С? #36410В 1С:Предприятии метод ПолучитьСеансыИнформационнойБазы() возвращает массив объектов типа СеансИнформационнойБазы, каждый из которых содержит информацию о текущих сеансах пользователей. В этих объектах есть свойства, которые позволяют получить данные о пользователе, но прямого свойства с правами пользователя там нет.
Чтобы получить права пользователя из сеанса, нужно из объекта сеанса получить имя пользователя, а затем уже через объект ПользователиИнформационнойБазы получить информацию о ролях (правах) этого пользователя.
Пример кода на 1С:
1С (Код)1234567891011121314151617181920Сеансы = ПользователиИнформационнойБазы.ПолучитьСеансыИнформационнойБазы();Для Каждого Сеанс Из Сеансы ЦиклИмяПользователя = Сеанс.Пользователь; // Имя пользователя из сеанса// Получаем список всех пользователейПользователи = ПользователиИнформационнойБазы.ПолучитьПользователей();Для Каждого Пользователь Из Пользователи ЦиклЕсли Пользователь.Имя = ИмяПользователя Тогда// Получаем роли пользователяРоли = Пользователь.Роли;Для Каждого Роль Из Роли Цикл// Имя роли - это и есть права пользователяСообщить("Пользователь: " + ИмяПользователя + ", Роль: " + Роль.Имя);КонецЦикла;Прервать; // нашли пользователя, можно выйти из циклаКонецЕсли;КонецЦикла;КонецЦикла;Объяснение:
— Получаем все активные сеансы.
— Для каждого сеанса берем имя пользователя.
— Получаем список всех пользователей информационной базы.
— Находим пользователя с таким именем.
— Из объекта пользователя берем список ролей — это и есть права доступа.
— Выводим или используем роли по необходимости.Прямого свойства с правами в объекте сеанса нет, поэтому нужно делать дополнительный запрос к пользователям.
Если нужна более детальная информация по ролям или правам, то можно дополнительно обращаться к объектам ролей и их настройкам через метаданные.
# Кратко:
— ПолучитьСеансыИнформационнойБазы() — получить сеансы.
— Из сеанса взять имя пользователя.
— Через ПользователиИнформационнойБазы.ПолучитьПользователей() получить роли пользователя.
— Роли — и есть права пользователя.Это стандартный способ получить права пользователя из сеансов в 1С.
14 апреля 2026 в 16:45 в ответ на: Как автоматически открыть обработку для пользователя при запуске 1С? #36408Чтобы при запуске 1С:Предприятия автоматически открыть определенную обработку для конкретного пользователя, нужно использовать обработчик события «ПередНачаломРаботыСистемы» в модуле приложения. В этом обработчике проверяется имя текущего пользователя, и если оно совпадает с нужным, то вызывается команда открытия обработки.
В приведённом примере проверяется, что имя пользователя равно «Кассир», и для него открывается обработка с указанным именем.
Обратите внимание, что в финальном коде используется функция ИмяПользователя() для получения имени пользователя и процедура ОткрытьФорму() для открытия обработки, а не создание экземпляра обработки и вызов ПолучитьФорму().Открыть(), как это иногда делают.
Если обработка внешняя, её нужно добавить в конфигурацию, чтобы можно было открыть по имени.
1С (Код)123456Процедура ПередНачаломРаботыСистемы(Отказ)ИмяПользователя = ИмяПользователя();Если ИмяПользователя = "Кассир" ТогдаОткрытьФорму("Обработка.ИмяОбработки");КонецЕсли;КонецПроцедуры14 апреля 2026 в 16:45 в ответ на: Как получить список пользователей 1С без привилегированного режима? #36406В 1С без использования привилегированного режима получить список других пользователей напрямую нельзя, если у текущего пользователя нет соответствующих прав. Это связано с тем, что платформа 1С строго контролирует доступ к данным пользователей и ролям.
Однако, если у вас есть доступ к объекту «ПользователиИнформационнойБазы» (например, в управляемом приложении), то можно получить список пользователей, но только тех, к которым у текущего пользователя есть доступ. Пример кода на встроенном языке 1С:
1С (Код)1234Пользователи = ПользователиИнформационнойБазы.ПолучитьПользователей();Для каждого Пользователь Из Пользователи ЦиклСообщить("Имя пользователя: " + Пользователь.Имя);КонецЦикла;Этот код не требует привилегированного режима, но вернет только тех пользователей, которые доступны текущему пользователю по правам.
Если же нужно получить полный список пользователей без ограничений, то это возможно только с использованием привилегированного режима:
1С (Код)1234567УстановитьПривилегированныйРежимИстина();Пользователи = ПользователиИнформационнойБазы.ПолучитьПользователей();УстановитьПривилегированныйРежимЛожь();Для каждого Пользователь Из Пользователи ЦиклСообщить("Имя пользователя: " + Пользователь.Имя);КонецЦикла;Без включения привилегированного режима платформа ограничит доступ к данным.
Если у вас нет возможности использовать привилегированный режим, то альтернативный вариант — запросить список пользователей через внешний механизм (например, через прямой SQL-запрос к базе данных, если это разрешено и безопасно), но это уже выходит за рамки стандартных возможностей 1С и требует прав администратора на уровне СУБД.
14 апреля 2026 в 15:30 в ответ на: Какая хозоперация для выдачи разменной монеты в кассу ККМ в 1С? #36404Шура, выдача разменной монеты в кассу ККМ — это хозяйственная операция по внесению наличных денежных средств в кассу предприятия. В 1С это оформляется как приходный кассовый ордер (ПКО) с видом операции «Внесение наличных в кассу» или «Внесение разменной монеты в кассу».
С бухгалтерской точки зрения это операция по увеличению кассовой наличности (счет 50) за счет собственных средств предприятия или средств, предназначенных для обеспечения кассы мелкими деньгами. В учете это отражается проводкой:
— Дебет 50 (Касса) — увеличение наличных денег в кассе
— Кредит 51 (Расчетный счет) или другой счет, с которого берутся деньги на разменЕсли разменная монета берется из кассы банка (например, из кассы филиала банка), то операция оформляется как получение наличных из банка (ПКО с видом операции «Получение наличных в банке»).
В 1С:Бухгалтерии и УТ это оформляется через документ «Приходный кассовый ордер» с соответствующим видом операции. В реквизитах указывается сумма, дата, касса, статья движения денежных средств (например, «Внесение разменной монеты»).
Если нужна конкретная настройка или обработка в 1С, могу помочь с кодом или алгоритмом.
14 апреля 2026 в 15:30 в ответ на: Какие справочники заполняются при покупке 1С:Альфа-Авто и как создать пользовате #36402Димон, привет!
В только что приобретённой базе 1С:Альфа-Авто Автосервис обычно сразу должны быть заполнены следующие справочники, чтобы можно было начать работу:
1. **Организации** — хотя бы одна организация, под которой ведется учет (можно изменить название и реквизиты, например, на вашу компанию).
2. **Контрагенты** — клиенты, поставщики, партнеры.
3. **Физические лица** — сотрудники, если планируется кадровый учет.
4. **Сотрудники организации** — для кадрового учета и назначения прав.
5. **Автомобили** — модели и конкретные автомобили клиентов.
6. **Модели автомобилей** — для правильного учета и обслуживания.
7. **Виды ремонтов и услуг** — перечень работ, которые выполняются в автосервисе.
8. **Номенклатура** — запчасти, материалы, работы.
9. **Склады** — места хранения запасных частей и материалов.
10. **Пользователи** — для разграничения доступа к базе.Это минимальный набор, который обычно уже частично заполнен в типовой базе, но многое придется корректировать под свои нужды.
—
**Как создать пользователя в 1С:Альфа-Авто:**
1. Перейдите в раздел **Администрирование** → **Пользователи** → **Пользователи**.
2. Нажмите кнопку **Создать** (через меню «Все действия» или клавишу Insert).
3. В открывшейся форме заполните:
— **Полное имя** — ФИО пользователя.
— **Имя для входа** — логин, под которым пользователь будет заходить в систему (может быть email).
4. При необходимости укажите дополнительные параметры, например, пароль, роли и права доступа.
5. Сохраните пользователя.После этого новый пользователь сможет войти в систему под своим логином.
—
Если нужна автоматизация приема сотрудников, в Альфа-Авто есть помощник «+Новый сотрудник», который сразу создаёт физическое лицо, сотрудника и документ приема на работу.
Если нужна помощь с конкретным кодом или настройкой — пиши, помогу.
14 апреля 2026 в 15:15 в ответ на: Как в 1С:КА запретить проведение документа с алкоголем и безалкоголкой? #36400В 1С:Комплексная автоматизация (КА) для запрета проведения документа «Реализация товаров и услуг» при наличии одновременно алкогольной и безалкогольной продукции в табличной части, нужно реализовать проверку в обработчике события проведения документа — например, в процедуре ПередПроведением() модуля объекта документа.
Алгоритм:
1. В модуле объекта документа «Реализация товаров и услуг» создайте процедуру ПередПроведением(Отказ).
2. В этой процедуре переберите строки табличной части с товарами, определите, есть ли в документе алкогольная продукция и есть ли безалкогольная.
3. Если одновременно есть и алкогольная, и безалкогольная продукция — установите Отказ = Истина и выведите сообщение об ошибке.
Пример кода на 1С:
1С (Код)1234567891011121314151617181920212223Процедура ПередПроведением(Отказ)ЕстьАлкоголь = Ложь;ЕстьБезалкоголь = Ложь;Для Каждого Строка Из ЭтотОбъект.Товары Цикл// Предполагается, что в справочнике номенклатуры есть реквизит "АлкогольнаяПродукция" типа БулевоЕсли Строка.Номенклатура.АлкогольнаяПродукция ТогдаЕстьАлкоголь = Истина;ИначеЕстьБезалкоголь = Истина;КонецЕсли;// Если оба флага уже установлены, можно прервать циклЕсли ЕстьАлкоголь И ЕстьБезалкоголь ТогдаПрервать;КонецЕсли;КонецЦикла;Если ЕстьАлкоголь И ЕстьБезалкоголь ТогдаОтказ = Истина;Сообщить("Документ не может быть проведен, так как содержит одновременно алкогольную и безалкогольную продукцию.");КонецЕсли;КонецПроцедурыОбъяснения:
— В примере предполагается, что у номенклатуры есть булевый реквизит «АлкогольнаяПродукция», который указывает, является ли товар алкогольным.
— Если такого реквизита нет, нужно либо добавить его, либо использовать другой способ определения алкогольной продукции (например, по группе номенклатуры или по признаку в характеристиках).
— Процедура ПередПроведением вызывается автоматически при попытке проведения документа, установка Отказ = Истина отменит проведение.
— Сообщение выводится пользователю, чтобы он понял причину отказа.
Если в вашей конфигурации есть более сложная логика определения алкогольной продукции (например, через ЕГАИС или отдельные реквизиты), адаптируйте проверку соответственно.
14 апреля 2026 в 14:00 в ответ на: Как установить галку «Привилегированный» для общего модуля в расширении в 1С? #36398Александр, привет!
В 1С:Предприятии при работе с расширениями конфигурации установить галку «Привилегированный» для общего модуля в расширении нельзя. Это ограничение платформы. Расширения не могут содержать привилегированные общие модули.
Объяснение:
— Привилегированные общие модули — это модули, которые имеют расширенные права доступа и могут выполнять операции, недоступные обычным модулям. Такие модули создаются только в основной конфигурации.
— В расширениях можно создавать общие модули, но они всегда работают в неприливилегированном режиме.
— Если вам нужно доработать привилегированный общий модуль, то это делается в основной конфигурации, а не в расширении.
— При попытке установить галку «Привилегированный» в расширении она будет недоступна или не сохранится.Если вам нужно расширить функциональность привилегированного общего модуля, используйте расширяющие методы с аннотациями &Перед, &После или &Вместо, но сам модуль останется непривилегированным.
Там подробно описано, что расширения не могут содержать привилегированные общие модули и как правильно работать с расширениями.
Если нужна помощь с конкретным кодом расширения или обходными путями — могу помочь.
14 апреля 2026 в 13:50 в ответ на: Как заполнить справочники при покупке базы 1С:Альфа-Авто (Автосервис)? #36396В типовой базе 1С:Альфа-Авто (Автосервис) после установки и первого запуска обычно сразу заполнены следующие справочники, чтобы можно было начать работу:
1. Организации — хотя бы одна организация с реквизитами (название, ИНН, КПП и т.п.).
2. Пользователи — в типовой базе есть пользователь <Не указан>, но новых пользователей нужно создавать вручную.
3. Сотрудники организации — справочник сотрудников, связанных с организацией.
4. Контрагенты — клиенты, поставщики, партнеры (часто пустой, нужно заполнять по мере работы).
5. Номенклатура — товары, услуги, запчасти, работы (частично может быть заполнена, но часто требует доработки под конкретный бизнес).
6. Автомобили — справочник моделей и конкретных автомобилей (частично может быть пустым).
7. Виды ремонтов, работ, услуг — справочники, которые нужны для формирования заказ-нарядов.
8. Склады — если ведется учет запасов.Часто база поставляется с минимальным набором данных, чтобы не мешать адаптации под конкретный бизнес.
—
### Как создать пользователя в 1С:Альфа-Авто (Автосервис)
1. Перейдите в раздел Администрирование → Пользователи.
2. Нажмите кнопку Создать (или через меню «Все действия» → «Создать»).
3. В форме нового пользователя заполните:
— Полное имя — ФИО пользователя.
— Имя для входа — логин, под которым пользователь будет заходить в систему.
— При необходимости укажите пароль (если используется аутентификация по паролю).
4. Сохраните пользователя.Если база работает с внешней аутентификацией (например, Windows), то логин должен совпадать с именем пользователя в домене.
—
Если база только что куплена и чистая, рекомендую сразу заполнить справочник Пользователи и назначить права доступа, чтобы обеспечить безопасность и разграничение доступа.
Рекомендую посмотреть здесь, как работать с пользователями и справочниками в 1С:
https://infostart.ru/public/522652/ (пример по Альфа-Авто и работе с пользователями)
https://infostart.ru/public/1393427/ (пример по Альфа-Авто и настройке базы)14 апреля 2026 в 13:45 в ответ на: Как исправить ошибку прав при использовании метода НайтиПоИмени в 1С? #36394Ошибка «Пользователю недостаточно прав для выполнения операции» при вызове метода ПользователиИнформационнойБазы.НайтиПоИмени возникает из-за того, что текущий пользователь не имеет прав на работу с объектом «ПользователиИнформационнойБазы» (администрирование пользователей).
Чтобы решить эту проблему, нужно:
1. Запускать код, который обращается к ПользователиИнформационнойБазы, в привилегированном режиме:
1С (Код)12345678УстановитьПривилегированныйРежим(Истина);ПопыткаПользовательИБ = ПользователиИнформационнойБазы.НайтиПоИмени(ИмяПользователя);// Ваш код работы с пользователемИсключение// Обработка ошибокКонецПопытки;УстановитьПривилегированныйРежим(Ложь);2. Убедиться, что у пользователя, под которым выполняется код, есть права на администрирование пользователей (роль с соответствующими полномочиями).
3. Если код вызывается из клиентского модуля, лучше перенести его в общий модуль с серверной обработкой или в серверный модуль, чтобы обеспечить выполнение с нужными правами.
4. Если вы пишете расширение или обработку, можно использовать специальный пользователь с полными правами для выполнения таких операций.
Если нужно массово работать с пользователями, то лучше делать это в контексте фоновой задачи или обработчика с правами администратора.
—
Пример функции с установкой привилегированного режима:
1С (Код)1234567891011Функция ПолучитьПользователяПоИмени(ИмяПользователя)УстановитьПривилегированныйРежим(Истина);ПопыткаПользовательИБ = ПользователиИнформационнойБазы.НайтиПоИмени(ИмяПользователя);Возврат ПользовательИБ;ИсключениеСообщить("Ошибка при поиске пользователя: " + ОписаниеОшибки());Возврат Неопределено;КонецПопытки;УстановитьПривилегированныйРежим(Ложь);КонецФункции—
Если привилегированный режим не помогает, значит у пользователя нет прав на администрирование пользователей, и нужно либо добавить ему соответствующую роль, либо выполнять операцию под другим пользователем.
Рекомендую посмотреть здесь:
https://infostart.ru/1c/articles/1085518/
https://helpf.pro/faq/view/161.html14 апреля 2026 в 11:30 в ответ на: Как устранить проблему при обновлении приложения 1С и найти ошибку в журнале? #36392
Ошибка обновления приложения с сообщением «Во время обновления приложения возникли некоторые проблемы. Информация о них сохранена в журнал регистрации» говорит о том, что процесс обновления не прошёл успешно, и детали ошибки записаны в журнал регистрации.
Что делать:
1. Откройте журнал регистрации обновления (обычно доступен через интерфейс платформы 1С или в папке с логами) и найдите конкретные ошибки или предупреждения, которые помогут понять причину сбоя.
2. Проверьте:
— Доступность файлов обновления (нет ли повреждённых или отсутствующих файлов).
— Права доступа пользователя, под которым выполняется обновление.
— Достаточно ли свободного места на диске.
— Совместимость версии обновления с текущей версией платформы и конфигурации.3. Если ошибка связана с конкретным модулем или объектом, попробуйте обновить его отдельно или вручную.
4. При необходимости обратитесь в техническую поддержку с приложением журнала регистрации.
Если нужна помощь с разбором журнала регистрации — приложите его содержимое, помогу проанализировать.
В 1С массив — это просто упорядоченный набор значений, у элементов массива нет полей, как у объектов или структур. Поэтому напрямую отсортировать массив по полю элементов нельзя, если элементы — не простые значения, а, например, структуры или объекты.
Чтобы отсортировать массив по полю элементов (например, если массив содержит структуры с одинаковым набором полей), нужно:
1. Преобразовать массив в СписокЗначений.
2. Загрузить в СписокЗначений элементы массива.
3. Вызвать метод СортироватьПоЗначению() — но он сортирует по значению элементов, а не по полю внутри структуры.
4. Чтобы сортировать именно по полю, нужно использовать ТаблицуЗначений, где можно указать сортировку по колонке.Пример сортировки массива структур по полю «Имя»:
1С (Код)1234567891011121314151617181920212223242526// Исходный массив структурМассив = Новый Массив;Массив.Добавить(Новый Структура("Имя,Возраст", "Иван", 30));Массив.Добавить(Новый Структура("Имя,Возраст", "Петр", 25));Массив.Добавить(Новый Структура("Имя,Возраст", "Алексей", 35));// Создаем таблицу значений с колонками, соответствующими полям структурТаблица = Новый ТаблицаЗначений;Таблица.Колонки.Добавить("Имя");Таблица.Колонки.Добавить("Возраст");// Заполняем таблицу значений из массиваДля Каждого Элемент Из Массив ЦиклНоваяСтрока = Таблица.Добавить();НоваяСтрока.Имя = Элемент.Имя;НоваяСтрока.Возраст = Элемент.Возраст;КонецЦикла;// Сортируем таблицу по колонке "Имя" по возрастаниюТаблица.Сортировать("Имя Возр");// Если нужно, можно выгрузить обратно в массив структурОтсортированныйМассив = Новый Массив;Для Каждого Строка Из Таблица ЦиклОтсортированныйМассив.Добавить(Новый Структура("Имя,Возраст", Строка.Имя, Строка.Возраст));КонецЦикла;Таким образом, сортировка по полю возможна через ТаблицуЗначений, а не напрямую в массиве.
Если элементы массива — простые значения (числа, строки), то можно использовать СписокЗначений и метод СортироватьПоЗначению().
https://helpf.pro/faq8/view/1364.html -
АвторСообщения
