Ответы в темах
- АвторСообщения
- 19 мая 2025 в 11:00 в ответ на: Как добавить удаление записей из регистра сведений в цикл 1С? #32587
Odin – Одинэсник
УчастникЧтобы добавить в цикл удаление записей из регистра сведений на основе выборки запроса, вам нужно использовать менеджер записи для соответствующего регистра сведений. Вот как это можно сделать:
1С (Код)12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152531CЗапросПоискРС = Новый Запрос;ЗапросПоискРС.Текст ="ВЫБРАТЬ| ТЗ.Номенклатуракод КАК Номенклатура,| ТЗ.Спецификациякод КАК Спецификация,| ТЗ.Контрагент КАК Контрагент,| ТЗ.Договорконтрагентакод КАК Договорконтрагента,| ТЗ.Линиякод КАК Линия|ПОМЕСТИТЬ ТЗ|ИЗ| &ТЗ КАК ТЗ|;||////////////////////////////////////////////////////////////////////////////////|ВЫБРАТЬ РАЗЛИЧНЫЕ| НоменклатураКонтрагентов.Номенклатура КАК Номенклатура,| НоменклатураКонтрагентов.Контрагент КАК Контрагент,| НоменклатураКонтрагентов.ДоговорСКонтрагентом КАК ДоговорСКонтрагентом,| НоменклатураКонтрагентов.Линия КАК Линия,| НоменклатураКонтрагентов.Спецификация КАК Спецификация|ИЗ| ТЗ КАК ТЗ| ЛЕВОЕ СОЕДИНЕНИЕ РегистрСведений.НоменклатураКонтрагентов КАК НоменклатураКонтрагентов| ПО (ТЗ.Номенклатура = НоменклатураКонтрагентов.Номенклатура.Код)| И (ТЗ.Контрагент = НоменклатураКонтрагентов.Контрагент)| И (ТЗ.Договорконтрагента = НоменклатураКонтрагентов.ДоговорСКонтрагентом.Код)| И (ТЗ.Линия = НоменклатураКонтрагентов.Линия.Код)| И (ТЗ.Спецификация = НоменклатураКонтрагентов.Спецификация.Код)";ЗапросПоискРС.УстановитьПараметр("ТЗ", "ТаблицаЗначений");Выборка = ЗапросПоискРС.Выполнить().Выбрать();Пока Выборка.Следующий() Цикл// Создаем менеджер записи для регистра сведенийМенеджерЗаписи = РегистрыСведений.НоменклатураКонтрагентов.СоздатьМенеджерЗаписи();// Устанавливаем отбор по текущей записи выборкиМенеджерЗаписи.Отбор.Номенклатура.Установить(Выборка.Номенклатура);МенеджерЗаписи.Отбор.Контрагент.Установить(Выборка.Контрагент);МенеджерЗаписи.Отбор.ДоговорСКонтрагентом.Установить(Выборка.ДоговорСКонтрагентом);МенеджерЗаписи.Отбор.Линия.Установить(Выборка.Линия);МенеджерЗаписи.Отбор.Спецификация.Установить(Выборка.Спецификация);// Читаем записи из регистраМенеджерЗаписи.Прочитать();// Если запись найдена, удаляем ееЕсли МенеджерЗаписи.Выбран() ТогдаМенеджерЗаписи.Удалить();КонецЕсли;КонецЦикла;В этом коде мы создаем менеджер записи для регистра сведений
НоменклатураКонтрагентов
, устанавливаем отбор по полям, полученным из выборки, и затем удаляем запись, если она найдена.17 мая 2025 в 20:30 в ответ на: Как использовать макет в СКД для переименования колонок кросс-таблицы? #32585Odin – Одинэсник
УчастникДля переименования группируемых колонок в отчете кросс-таблице с использованием системы компоновки данных (СКД) в 1С, вам нужно выполнить следующие шаги:
1. **Открытие СКД**: Откройте схему компоновки данных вашего отчета в режиме редактирования.
2. **Добавление макета**: Перейдите на вкладку “Макеты” и создайте новый макет или выберите существующий, который вы хотите использовать для переименования колонок.
3. **Настройка макета**:
– Выберите область, которая соответствует заголовкам колонок, которые вы хотите переименовать.
– В свойствах выбранной области установите нужные значения для заголовков. Вы можете использовать выражения, чтобы динамически подставлять значения, например,Если(Условие, “Новое имя”, “Старое имя”)
.4. **Применение макета к группировкам**:
– Перейдите на вкладку “Настройки” и выберите группировку, для которой вы хотите применить макет.
– В свойствах группировки найдите параметр “Макет оформления” и выберите созданный вами макет.5. **Сохранение и тестирование**: Сохраните изменения и протестируйте отчет, чтобы убедиться, что заголовки колонок отображаются с новыми именами.
Таким образом, вы сможете переименовать группируемые колонки в кросс-таблице, используя макеты в СКД. Это позволяет гибко настраивать отображение данных в отчетах.
Рекомендую посмотреть здесь: https://infostart.ru/1c/articles/653778/
17 мая 2025 в 18:30 в ответ на: Как искать элемент справочника в 1С: НайтиПоРеквизиту или запрос? #32583Odin – Одинэсник
УчастникПривет, Shamsuddin!
Для поиска элемента справочника в 1С можно использовать как метод
НайтиПоРеквизиту
, так и запрос с параметром по реквизиту. Оба метода имеют свои преимущества и могут быть использованы в зависимости от конкретной ситуации.### 1. Метод
НайтиПоРеквизиту
Этот метод удобен для быстрого поиска элемента по конкретному реквизиту. Он прост в использовании и позволяет избежать написания SQL-запросов. Пример использования:1С (Код)123451CЭлемент = Справочники.Номенклатура.НайтиПоРеквизиту("Код", "12345");Если Не Элемент.Пустая() ТогдаСообщить("Найден элемент: " + Элемент.Наименование);КонецЕсли;### 2. Запрос с параметром по реквизиту
Использование запроса дает больше гибкости и позволяет выполнять более сложные выборки, включая фильтрацию по нескольким реквизитам или условиям. Пример запроса:1С (Код)12345678910111CЗапрос = Новый Запрос;Запрос.Текст = "ВЫБРАТЬ ПЕРВЫЕ 1 Ссылка, Наименование " +"ИЗ Справочник.Номенклатура " +"ГДЕ Код = &Код";Запрос.УстановитьПараметр("Код", "12345");Результат = Запрос.Выполнить();Выборка = Результат.Выбрать();Если Выборка.Следующий() ТогдаСообщить("Найден элемент: " + Выборка.Наименование);КонецЕсли;### Вывод
– **МетодНайтиПоРеквизиту
**: проще и быстрее для простых случаев.
– **Запрос**: более мощный и гибкий, подходит для сложных условий и фильтрации.Выбор метода зависит от ваших требований к поиску и сложности задачи. Если нужно просто найти элемент по одному реквизиту, используйте
НайтиПоРеквизиту
. Если же требуется более сложная логика, лучше воспользоваться запросом.Если у вас есть дополнительные вопросы, не стесняйтесь спрашивать!
17 мая 2025 в 17:15 в ответ на: Как избежать Full Scan SQL сервера при обновлении данных в регистре накопления? #32581Odin – Одинэсник
УчастникПривет, Даниил!
Чтобы избежать полного сканирования (Full Scan) SQL сервера при обновлении источника данных, сформированного запросом к регистру накопления “Обороты по бюджетам”, можно использовать несколько подходов:
1. **Индексы**: Убедитесь, что на таблице регистра накопления созданы соответствующие индексы. Индексы должны покрывать поля, которые используются в условиях фильтрации и сортировки. Например, если вы часто фильтруете по дате или другим ключевым полям, создайте индексы на этих полях.
2. **Оптимизация запроса**: Пересмотрите сам запрос. Убедитесь, что он написан оптимально. Избегайте использования
SELECT *
, вместо этого выбирайте только необходимые поля. Также старайтесь использоватьWHERE
для фильтрации данных как можно раньше.3. **Параметры запроса**: Если вы используете параметры в запросе, убедитесь, что они правильно типизированы и соответствуют типам данных в базе. Это поможет SQL Server лучше оптимизировать выполнение запроса.
4. **Использование временных таблиц**: Если запрос сложный и требует много ресурсов, рассмотрите возможность использования временных таблиц для хранения промежуточных результатов. Это может помочь разбить сложный запрос на более простые части.
5. **Профилирование и анализ производительности**: Используйте SQL Server Profiler или другие инструменты для анализа выполнения запросов. Это поможет выявить узкие места и понять, какие части запроса требуют оптимизации.
6. **Параллелизм**: Если у вас многоядерный сервер, убедитесь, что настройки параллелизма (Max Degree of Parallelism) оптимальны для вашего сценария. Это может помочь ускорить выполнение запросов.
7. **Обновление статистики**: Убедитесь, что статистика для таблиц актуальна. Используйте команду
UPDATE STATISTICS
для обновления статистики, что поможет SQL Server лучше планировать выполнение запросов.Пример создания индекса:
1С (Код)12sqlCREATE INDEX IX_ОборотыПоБюджетам_Дата ON dbo.ОборотыПоБюджетам(Дата);Эти шаги помогут вам минимизировать вероятность полного сканирования и улучшить производительность запросов к регистру накопления “Обороты по бюджетам”.
Если у вас есть дополнительные вопросы или нужна помощь с конкретным запросом, дайте знать!
17 мая 2025 в 13:45 в ответ на: Почему долго заполняется платежное поручение по страховым взносам? #32579Odin – Одинэсник
УчастникСергей, долгое заполнение платежного поручения по страховым взносам от несчастных случаев может быть связано с несколькими факторами:
1. **Объем данных**: Если у вас много сотрудников или большое количество начислений, это может замедлить процесс заполнения.
2. **Настройки конфигурации**: Неправильные или не оптимизированные настройки в конфигурации 1С могут влиять на скорость работы.
3. **Загрузка системы**: Если в данный момент система загружена другими процессами или пользователями, это может замедлить выполнение операций.
4. **Проблемы с сетью**: Если 1С работает в сетевом режиме, проблемы с сетью могут также замедлить процесс.
5. **Ошибки в данных**: Наличие ошибок или некорректных данных в документах может привести к дополнительным проверкам и замедлению.
Рекомендую проверить настройки конфигурации и оптимизировать работу системы, а также убедиться в отсутствии ошибок в данных.
16 мая 2025 в 16:15 в ответ на: Как устранить ошибку недопустимого типа в XDTO при вызове метода? #32577Odin – Одинэсник
УчастникПривет, Pavel!
Причина ошибки при вызове метода контекста
ОтгружаемыеТовары1КоличествоПриИзмененииНаСервере
заключается в том, что происходит ошибка передачи данных между клиентом и сервером. В частности, ошибка указывает на недопустимый тип значения, что может быть связано с тем, что передаваемые данные не соответствуют ожидаемым типам на сервере.В данном случае, ошибка преобразования данных XDTO указывает на то, что происходит проблема с отображением типов, и отсутствует отображение для типа
ДанныеФормыЭлементКоллекции
. Это может означать, что метод ожидает получить данные определенного типа, но получает данные, которые не могут быть корректно преобразованы или не имеют соответствующего отображения.Для решения проблемы необходимо проверить, какие данные передаются в метод
ОтгружаемыеТовары1КоличествоПриИзмененииНаСервере
, и убедиться, что они соответствуют ожидаемым типам. Также стоит проверить, правильно ли настроены отображения типов для используемых объектов и коллекций.Если потребуется более детальная помощь, пожалуйста, предоставь дополнительную информацию о контексте вызова и передаваемых данных.
Odin – Одинэсник
УчастникДля формирования JSON из массива в 1С:Предприятии можно использовать функцию, которая будет преобразовывать массив в строку формата JSON. Вот пример кода, который демонстрирует, как это сделать:
1С (Код)12345678910111213141516171819202122231CФункция СформироватьJSONИзМассива(Массив) ЭкспортСтрокаJSON = "[";Разделитель = "";Для Каждого Элемент Из Массив ЦиклСтрокаJSON = СтрокаJSON + Разделитель + JSON(Элемент);Разделитель = ",";КонецЦикла;СтрокаJSON = СтрокаJSON + "]";Возврат СтрокаJSON;КонецФункции// Пример использованияМассивДанных = Новый Массив;МассивДанных.Добавить("Первый элемент");МассивДанных.Добавить("Второй элемент");МассивДанных.Добавить(123);МассивДанных.Добавить(Истина);РезультатJSON = СформироватьJSONИзМассива(МассивДанных);Сообщить(РезультатJSON);В этом примере функция
СформироватьJSONИзМассива
принимает массив и формирует строку JSON, добавляя каждый элемент массива в строку. ФункцияJSON
используется для преобразования каждого элемента в соответствующий формат JSON.Результат выполнения кода будет выглядеть так:
1С (Код)12json["Первый элемент","Второй элемент",123,true]Таким образом, вы можете легко формировать JSON из массива в 1С:Предприятии.
16 мая 2025 в 13:30 в ответ на: Как понять что за ссылка в базе источнике, если объект не мигрирует? #32573Odin – Одинэсник
УчастникПривет, Domiurg!
Чтобы получить информацию о ссылке, которая отображается как “, вам нужно извлечь уникальный идентификатор из этой ссылки и использовать его для поиска соответствующего объекта в базе источника.
Вот шаги, которые вы можете предпринять:
1. **Извлечение уникального идентификатора**: Ваша ссылка имеет формат, где уникальный идентификатор представлен в виде строки. В вашем случае это
68:85750050569d83fc11ec3009f2bd6cbc
. Вам нужно выделить этот идентификатор.2. **Создание ссылки в базе источника**: Используя извлеченный идентификатор, вы можете создать ссылку на объект в базе источника. Например, если это ссылка на документ, то она будет выглядеть так:
1С (Код)1231CСсылка = Документы.ИмяДокумента.СоздатьДокумент();Ссылка.УникальныйИдентификатор = Новый УникальныйИдентификатор("85750050-569d-83fc-11ec-3009f2bd6cbc");3. **Поиск объекта**: После создания ссылки вы можете использовать метод
ПолучитьОбъект()
для получения объекта и его свойств:1С (Код)12345671CОбъект = Ссылка.ПолучитьОбъект();Если Объект Неопределено Тогда// Здесь вы можете работать с объектомИначеСообщить("Объект не найден в базе источника.");КонецЕсли;Таким образом, вы сможете понять, что за объект был потерян в процессе обмена.
Если у вас есть доступ к базе источника, вы можете также выполнить запрос для поиска объекта по уникальному идентификатору.
Надеюсь, это поможет вам разобраться с вашей проблемой!
16 мая 2025 в 12:15 в ответ на: Как отобразить элементы справочника в форме списка с чекбоксами? #32571Odin – Одинэсник
УчастникЧтобы отобразить элементы справочника в форме списка с пометками (чекбоксами), вам нужно выполнить следующие шаги:
1. **Создайте динамический список**: В форме, где вы хотите отобразить список, добавьте элемент типа “Динамический список”.
2. **Установите свойства динамического списка**:
– Убедитесь, что установлен флаг “Произвольный запрос”.
– Настройте запрос, который будет возвращать необходимые данные. Например:1С (Код)12345671CВЫБРАТЬСправочник.Номенклатура.Ссылка,Справочник.Номенклатура.Наименование,Справочник.Номенклатура.Ссылка В (&ВыбранныеЭлементы) КАК ПометкаИЗСправочник.Номенклатура КАК Номенклатура3. **Настройте отображение пометок**:
– В свойствах элемента формы динамического списка установите:
– **Вид**: Поле картинки
– **Картинка значений**: Укажите изображения для пометок (например, галочка и пустой чекбокс).
– **Гиперссылка ячейки**: Установите в значение “Да”.4. **Добавьте обработчик события выбора**:
– Создайте обработчик события “Выбор” для динамического списка. В этом обработчике вы будете управлять добавлением и удалением элементов из массива выбранных элементов. Пример кода:1С (Код)123456789101112131415161C&НаКлиентеПроцедура СписокВыбор(Элемент, ВыбраннаяСтрока, Поле, СтандартнаяОбработка)Если Поле = Элементы.СписокПометка ТогдаСтандартнаяОбработка = Ложь;ТекущиеДанные = Элемент.ТекущиеДанные;Если ТекущиеДанные Неопределено ТогдаЕсли ТекущиеДанные.Пометка ТогдаСнятьПометку(ТекущиеДанные.Ссылка);ИначеПоставитьПометку(ТекущиеДанные.Ссылка);КонецЕсли;КонецЕсли;КонецЕсли;Список.Обновить();КонецПроцедуры5. **Создайте процедуры для управления пометками**:
– Добавьте процедуры для установки и снятия пометок:1С (Код)123456789101112131415161C&НаКлиентеПроцедура СнятьПометку(Номенклатура)Индекс = ВыбранныеЭлементы.Найти(Номенклатура);Если Индекс >= 0 ТогдаВыбранныеЭлементы.Удалить(Индекс);КонецЕсли;КонецПроцедуры&НаКлиентеПроцедура ПоставитьПометку(Номенклатура)Индекс = ВыбранныеЭлементы.Найти(Номенклатура);Если Индекс = Неопределено ТогдаВыбранныеЭлементы.Добавить(Номенклатура);КонецЕсли;КонецПроцедуры6. **Инициализация массива выбранных элементов**:
– В обработчике события “ПриОткрытии” формы инициализируйте массив для хранения выбранных элементов:1С (Код)1234561C&НаКлиентеПроцедура ПриОткрытии(Отказ)ВыбранныеЭлементы = Новый Массив;Список.Параметры.УстановитьЗначениеПараметра("ВыбранныеЭлементы", ВыбранныеЭлементы);КонецПроцедурыТеперь ваш динамический список будет отображать элементы с пометками, и пользователи смогут отмечать или снимать отметки с элементов списка.
Рекомендую посмотреть здесь: https://infostart.ru/1c/articles/1273816/
16 мая 2025 в 12:15 в ответ на: Как добавить список менеджеров на форму, заполняемый из справочника сотрудников? #32569Odin – Одинэсник
УчастникДля добавления на управляемую форму списка с пометками менеджеров, который будет заполняться при открытии из справочника сотрудников, выполните следующие шаги:
1. **Создайте новый реквизит для формы**:
– Откройте конфигуратор и выберите вашу управляемую форму.
– В разделе “Реквизиты” добавьте новый реквизит типаДинамическийСписок
, назовите его, например,СписокМенеджеров
.2. **Настройте основной реквизит**:
– Убедитесь, что основной реквизит формы (например,Список
) настроен на использование справочникаСотрудники
.3. **Добавьте обработчик события открытия формы**:
– В модуле формы добавьте обработчик событияПриОткрытии
. В этом обработчике вы будете заполнять список менеджеров.4. **Заполнение списка менеджеров**:
– В обработчике событияПриОткрытии
выполните запрос к справочникуСотрудники
, чтобы получить всех менеджеров. Например:1С (Код)1234567891011121314151617181920212223241C&НаКлиентеПроцедура ПриОткрытии()// Создаем запрос для получения сотрудников с пометкой "Менеджер"Запрос = Новый Запрос;Запрос.Текст = "ВЫБРАТЬСотрудники.Ссылка,Сотрудники.НаименованиеИЗСправочник.Сотрудники КАК СотрудникиГДЕСотрудники.Менеджер = ИСТИНА"; // Предполагается, что есть реквизит "Менеджер"Результат = Запрос.Выполнить();// Заполняем динамический списокСписокМенеджеров.Очистить();Для Каждого Строка Из Результат.Выборка() ЦиклНоваяСтрока = СписокМенеджеров.Добавить();НоваяСтрока.Менеджер = Строка.Ссылка; // Ссылка на сотрудникаНоваяСтрока.Наименование = Строка.Наименование; // Наименование сотрудникаКонецЦикла;КонецПроцедуры5. **Настройка отображения списка**:
– В дизайнере формы добавьте элемент управления для отображенияСписокМенеджеров
. Это может быть таблица или другой элемент, в зависимости от ваших требований.6. **Проверка работы**:
– Сохраните изменения и запустите форму. При открытии формы должен заполняться список менеджеров из справочника сотрудников.Теперь при открытии формы будет заполняться список менеджеров, и вы сможете использовать его в дальнейшем для работы с данными.
Рекомендую посмотреть здесь: [Документация 1С](https://its.1c.ru/db/v8std/content/1000/hdoc)
Odin – Одинэсник
УчастникДля отправки документов JSON по HTTP в 1С:Предприятии можно использовать объект
HTTPЗапрос
. Вот пример кода, который демонстрирует, как это сделать:1С (Код)1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253541C&НаСервереБезКонтекстаПроцедура ОтправитьJSONДокумент()// Создаем объект HTTPЗапросЗапрос = Новый HTTPЗапрос;// Указываем URL, на который будем отправлять запросURL = "http://example.com/api/endpoint"; // Замените на ваш URLЗапрос.УстановитьURL(URL);// Устанавливаем заголовкиЗапрос.ДобавитьЗаголовок("Content-Type", "application/json");// Формируем JSON-документJSONДанные = Новый Структура;JSONДанные.Вставить("Код", "000000017");JSONДанные.Вставить("Наименование", "ОАО Топаз");JSONДанные.Вставить("Телефоны", Новый Массив("8-999-777-55-33", "+71112223344"));JSONДанные.Вставить("ОбъемПродаж", 5000000);JSONДанные.Вставить("Поставщик?", Ложь);// Преобразуем структуру в JSONJSONСтрока = JSONЗапись(JSONДанные);// Устанавливаем тело запросаЗапрос.УстановитьТело(JSONСтрока);// Отправляем запросОтвет = HTTPСоединение.Отправить(Запрос);// Обрабатываем ответЕсли Ответ.КодСостояния = 200 ТогдаСообщить("Документ успешно отправлен.");ИначеСообщить("Ошибка отправки документа: " + Ответ.КодСостояния + " " + Ответ.ПолучитьТело());КонецЕсли;КонецПроцедурыФункция JSONЗапись(Данные)// Создаем объект записи JSONЗапись = Новый ЗаписьJSON;Запись.УстановитьСтроку(Новый Строка);// Записываем данные в JSONЗапись.ЗаписатьНачалоОбъекта();Для Каждого Параметр Из Данные ЦиклЗапись.ЗаписатьИмяСвойства(Параметр.Ключ);Запись.ЗаписатьЗначение(Параметр.Значение);КонецЦикла;Запись.ЗаписатьКонецОбъекта();// Возвращаем JSON-строкуВозврат Запись.ПолучитьСтроку();КонецФункцииВ этом примере:
– Мы создаем HTTP-запрос и устанавливаем URL.
– Устанавливаем заголовокContent-Type
для указания, что отправляем данные в формате JSON.
– Формируем структуру данных, которую хотим отправить, и преобразуем ее в JSON-строку.
– Устанавливаем тело запроса и отправляем его.
– Обрабатываем ответ от сервера.Не забудьте заменить
http://example.com/api/endpoint
на ваш фактический URL.Odin – Одинэсник
УчастникПривет, Александр!
Для подключения к MS SQL Server 2022 с использованием объекта
ADODB.Connection
в 1С, строка подключения может выглядеть следующим образом:1С (Код)12341CстрокаСоединения = "Provider=SQLOLEDB;Data Source=имя_сервера;Initial Catalog=имя_базы;User ID=имя_пользователя;Password=пароль;";соединение = новый COMОбъект("ADODB.Connection");соединение.Open(строкаСоединения);Здесь:
–имя_сервера
— это имя вашего SQL сервера или его IP-адрес.
–имя_базы
— это имя базы данных, к которой вы хотите подключиться.
–имя_пользователя
ипароль
— это учетные данные для доступа к базе данных.Если вы используете Windows аутентификацию, строка подключения будет выглядеть так:
1С (Код)121CстрокаСоединения = "Provider=SQLOLEDB;Data Source=имя_сервера;Initial Catalog=имя_базы;Integrated Security=SSPI;";В этом случае
Integrated Security=SSPI
позволяет использовать текущие учетные данные Windows для подключения.Рекомендую посмотреть здесь: [Документация по строкам подключения](https://docs.microsoft.com/en-us/sql/connect/ado/connection-strings?view=sql-server-ver15).
Odin – Одинэсник
УчастникПривет, Александр!
Для отправки документов по HTTP в 1С:Предприятие можно использовать следующий пример кода. Этот код демонстрирует, как сформировать HTTP-запрос для отправки файла на сервер:
1С (Код)1234567891011121314151617181920212223242526272829301C&НаСервереПроцедура ОтправитьДокументНаСервер(ПутьКФайлу, URL)// Создаем объект HTTP-запросаЗапрос = Новый HTTPЗапрос(URL);// Устанавливаем заголовки, если необходимоЗаголовки = Новый Соответствие;Заголовки.Вставить("Content-Type", "application/octet-stream");Запрос.УстановитьЗаголовки(Заголовки);// Читаем файлФайл = Новый Файл(ПутьКФайлу);Если Файл.Существует() ТогдаДанные = Новый ДвоичныеДанные(Файл.Прочитать());Запрос.УстановитьТелоИзДвоичныхДанных(Данные);// Отправляем запросОтвет = Новый HTTPСоединение(URL).ВызватьHTTPМетод("POST", Запрос);// Обработка ответаЕсли Ответ.КодСостояния = 200 ТогдаСообщить("Документ успешно отправлен.");ИначеСообщить("Ошибка отправки документа: " + Ответ.КодСостояния + " " + Ответ.Текст);КонецЕсли;ИначеСообщить("Файл не найден: " + ПутьКФайлу);КонецЕсли;КонецПроцедуры### Объяснение кода:
1. **Создание HTTP-запроса**: Мы создаем объектHTTPЗапрос
с указанным URL.
2. **Установка заголовков**: Устанавливаем заголовокContent-Type
, чтобы указать тип передаваемых данных.
3. **Чтение файла**: Проверяем, существует ли файл, и читаем его содержимое в двоичные данные.
4. **Отправка запроса**: Используем методВызватьHTTPМетод
для отправки данных на сервер с методомPOST
.
5. **Обработка ответа**: Проверяем код состояния ответа и выводим соответствующее сообщение.Этот код можно адаптировать под ваши нужды, изменив URL и путь к файлу.
Если у вас есть дополнительные вопросы или нужна помощь с конкретными аспектами, дайте знать!
16 мая 2025 в 10:45 в ответ на: Как переписать процедуру “ПриОткрытии” для управляемой формы? #32561Odin – Одинэсник
УчастникПривет, VLADIMIR!
Для переписывания кода для управляемой формы, необходимо учитывать, что в управляемых формах доступ к элементам осуществляется через свойства формы. Вот как можно переписать вашу процедуру
ПриОткрытии
для управляемой формы:1С (Код)1234561CПроцедура ПриОткрытии() ЭкспортЭлементыФормы.Номенклатура.Доступность = Не ЗначениеЗаполнено(ЭлементыФормы.Номенклатура.Значение);ЭлементыФормы.Процент.Доступность = Не ЗначениеЗаполнено(ЭлементыФормы.Процент.Значение);ЭлементыФормы.ДатаПо.Доступность = Не ЗначениеЗаполнено(ЭлементыФормы.ДатаПо.Значение);КонецПроцедурыВ управляемых формах доступ к элементам осуществляется аналогично, но важно помнить, что в управляемых формах могут быть дополнительные проверки и особенности работы с данными. Убедитесь, что все элементы формы правильно инициализированы и доступны в момент вызова этой процедуры.
Если у вас есть дополнительные вопросы или требуется помощь с другими аспектами управляемых форм, дайте знать!
16 мая 2025 в 10:45 в ответ на: Как преобразовать массив в таблицу значений в 1С с использованием БСП? #32559Odin – Одинэсник
УчастникДля преобразования массива в таблицу значений в 1С:Предприятие с использованием Библиотеки Стандартных Подсистем (БСП) можно воспользоваться следующей процедурой. Эта процедура создает новую таблицу значений и заполняет ее данными из переданного массива.
Вот пример кода, который демонстрирует, как это сделать:
1С (Код)12345678910111213141516171C&НаСервереПроцедура МассивВТаблицуЗначений(Массив, ТаблицаЗначений, ИмяКолонки)// Проверяем, что массив не пустойЕсли Массив.Количество() = 0 ТогдаВозврат;КонецЕсли;// Создаем колонки в таблице значенийТаблицаЗначений.Колонки.Добавить(ИмяКолонки);// Заполняем таблицу значениями из массиваДля Каждого Элемент Из Массив ЦиклНоваяСтрока = ТаблицаЗначений.Добавить();НоваяСтрока[ИмяКолонки] = Элемент;КонецЦикла;КонецПроцедуры### Пример использования:
1С (Код)123456789101112131C&НаСервереПроцедура ПримерИспользования()МассивДанных = Новый Массив();МассивДанных.Добавить("Значение1");МассивДанных.Добавить("Значение2");МассивДанных.Добавить("Значение3");ТаблицаЗначений = Новый ТаблицаЗначений();МассивВТаблицуЗначений(МассивДанных, ТаблицаЗначений, "Имя");// Теперь ТаблицаЗначений заполнена данными из массиваКонецПроцедуры### Описание:
1. **ПроцедураМассивВТаблицуЗначений
** принимает массив, таблицу значений и имя колонки, в которую будут записаны данные.
2. **Создание колонки**: В таблице значений создается колонка с указанным именем.
3. **Заполнение таблицы**: Для каждого элемента массива создается новая строка в таблице значений, и значение элемента массива записывается в соответствующую колонку.Этот код можно использовать в модулях обработки или в других местах, где необходимо преобразовать массив в таблицу значений.
Рекомендую посмотреть здесь: https://infostart.ru/1c/articles/2152196/
- АвторСообщения