| Код |
|---|
if(CModule::IncludeModule("iblock")){
$id_catalog = 8;
$prop = [];
$order = ['ID' => 'ASC'];
$filter = ['IBLOCK_ID' => $id_catalog];
$rows = CIBlockElement::GetList($order, $filter);
while ($row = $rows->fetch()) {
$row['PROPERTIES'] = [];
$prop[$row['ID']] =& $row;
unset($row);
}
//Получаю массив со всеми свойствами всех элементов
CIBlockElement::GetPropertyValuesArray($prop, $filter['IBLOCK_ID'], $filter);
unset($rows, $filter, $order);
//перезаписываю в массив $arCodeValue нужное свойство
$arCodeValue = [];
foreach ($prop as $key => $value) {
if(!empty($value)){
while(strstr($value['PROPERTIES']['VOLUME']['VALUE'], ',')){
$value['PROPERTIES']['VOLUME']['VALUE'] = str_replace(',','.',$value['PROPERTIES']['VOLUME']['VALUE']);
$arCodeValue[$key] = [$value['PROPERTIES']['VOLUME']['ID'] => $value['PROPERTIES']['VOLUME']['VALUE']];
}
}else echo 'empty';
}
//До этого всё выполняется быстро, а последний цикл как раз даёт много запросов бд
//Записываю массив $arCodeValue при помощи SetPropertyValuesEx
//Сохраняю при помощи Update
foreach ($prop as $key => $value) {
if(!empty($value) && strstr($value['PROPERTIES']['VOLUME']['VALUE'], ',')){
CIBlockElement::SetPropertyValuesEx($key, $id_catalog, $arCodeValue[$key]);
$elthis = new CIBlockElement;
$elthis->Update(
$key,
[ 'WF_STATUS_ID' => 1, 'ACTIVE' => 'Y' ],
true
);
echo $key;
echo ' ';
unset($elthis);
}
}
}
|
Массовая перезапись свойства элемента в каталоге
|
Владислав: 18.11.2022 07:00:00
Здравствуйте, нужно обновить определённое свойство, а точнее его перезаписать так как с 1С приходят данные с запятой, а нужны в общем то с точкой. Написал следующий скрипт, но не нашёл в Апи битрикса как записать 1 запросом данные, я так понимаю на каждый setProperyValueEx и Update идёт запрос к базе, ну следовательно вылезает что время запроса к базе превышено и скрипт выполняется не полностью. Если поставить время запроса больше то отваливается апач от браузера, тестил на локальном сервере. Подскажите как это всё грамотно сделать пожалуйста.
|
|
Михаил Базаров: 18.11.2022 10:00:00
Не сильно вчитался в скрипт, но не очень понял зачем:
CIBlockElement::SetPropertyValuesEx и без этого должно сохранить значение. Если совсем много, сделайте скрипт пошаговым. Пример тут, там не очень феншуйно и немного говнокодства, но если единоразово нужен, вполне сгодится. https://bazarow.ru/forum/forum11/641-poshagovaya-obrabotka-bolshogo-kolichestva-elementov-infobloka_-bystro-skript |
|
Владислав: 20.11.2022 03:00:00
|
Блог-note Заметки по 1С-Битрикс
-
Настройка push уведомлений через Firebase в приложении Apache Cordova
Задача: Apache Cordova предоставляет удобный способ разработки кроссплатформенных мобильных приложений. В данной статье расскажу, как настроить отправ...
-
Вывести дату окончания скидки в карточке товара
Вывести информацию о скидке в карточке товара, методом CCatalogDiscount::GetList. Данный метод позволяет получить любую информацию о скидке. Заметка н...
-
Если товар в корзине, поменять значение input на "В корзине"
Если Вам нужно поменять текст на кнопке, добавляющей товар в корзину, достаточно воспользоваться методом API "CSaleBasket::GetList - который возвращае...
-
Удалить половину элементов инфоблока с помощью API
Задача: вот такая странная задача, нужно удалить из инфоблока половину элементов. Не важно каких, просто половину элементов.
-
Отфильтровать товары бренда и вывести по разделам каталога
Задача: на странице бренда, который выводится компонентом новостей, нужно показать все товары этого бренда из каталога. При этом, товары нужно вывест...
-
Локальный Copilot в PhpStorm / VSCode, с помощью Continue. Свой, бесплатный Cursor
Это краткий план-черновик для видео (само видео ниже). В нем рассказывается о том, как запустить локальную ИИ модель и подключить её к проекту...