Как Claude и Ollama решили мою вечную проблему на Ozon

от автора

Меня зовут Миша, я руководитель группы дизайна в Ozon Seller, а еще я сам являюсь селлером и продаю ножи на Ozon уже более 6 лет. И моей вечной болью и проблемой была работа с сертификатами качества.

У Ozon часто меняются правила к требованиям по сертификации ножей — то они обязательно нужны, то не обязательно, то по требованию клиентов. И наконец, с 1 октября 2026 года вступает в силу Федеральный закон о платформенной экономке, который в явном виде приписывает требования к сертификации изделий, конструктивно сходными с оружием, то есть ножей. Ozon решил начать проверки заранее и в один день заблокировал почти весь мой ассортимент.

Как я делал раньше: 

  • Ozon блокирует какой-то товар или несколько 

  • Я захожу в раздел сертификатов качества в Ozon Seller 

  • Загружаю туда поштучно сертификат и приложение к нему

  • И привязываю к этому сертификату подходящие товары 

Так как в этот раз Ozon мне заблокировал около 1000 SKU, такой подход обошелся бы мне в несколько месяцев рутины и ада. Усложняется еще все тем, что сертификаты — это не PDF, откуда просто можно собрать данные, а просто картинка в JPEG, которая хранится на Гугл диске.

Поэтому единственным возможным решением оказалось распознание текста на картинке через ИИ и загрузка сертификатов/привязка товаров по API в Ozon Seller. 

При этом, если просто попросить того же Клода спарсить такие картинки, я бы сжег все лимиты уже на 10-20 картинке. А мне нужно распознать около 500 картинок. Поэтому тут понадобится локальная модель. 

Итак, как же решить эту задачу? 

Этап 1. Скачать локальную модель

Для этой задачи я выбрал модель qwen3-vl:8b («The most powerful vision-language model in the Qwen model family to date»), скачать и установить ее можно через Ollama, весит 6GB:

ollama run qwen3-vl:8b

Кстати, я взял самую большую модель (8b), но для этой задачи могла бы подойти и поменьше (2b, 4b) и тогда обработка бы заняла меньше времени.

Этап 2. Описать Клоду задачу

Первый мой промт выглядел так: 

👨🏻‍💻 Я:

напиши скрипт для локальной модели qwen3-vl:8b в ollama, чтобы он проанализировал все картинки сертификатов ножей и выделил оттуда номер сертификата и артикулы, которые к нему привязаны. пример сертификата и приложения приложил. на входе я дам ссылку на Google Drive с сертификатами на выходе я хочу получить табличку в google sheets, где будут колонки: «фото сертификата» (ссылка на него в GD); «фото  приложения» (ссылка на него в GD) — приложение связано по номеру сертификата; «номер сертификата» (POCC RU C-US.MЖ55.A.07230/21); «дата начала» действия сертификата (15.07.2021); «дата окончания» (если есть); «артикулы товаров» из приложения через запятую (20KR5, 20KR7, 20KR9, 27BAC, 27BAS, 23JB и тд); «название» — можно любое, например последние цифры номера (07230/21)

Он написал какой-то скрипт, я его даже не проверял, потому что понял, что интеграция с Гуглом это как-то слишком сложно для такой задачи, поэтому написал новый промт: 

👨🏻‍💻 Я:

и давай сделаем скрипт для локальной папки, без интеграции с google 
у меня есть папка со всеми сертификатами, а создать можно локальный файл csv
только не знаю что делать с картинками — на выходе должна быть ссылка (может есть решение с бесплатным хостингом?)
вообще, все это нужно, чтобы подготовить данные к добавлению сертификатов в Ozon по API: https://docs.ozon.ru/api/seller/#operation/ProductAPI_ProductCertificateCreate 
может есть идеи как это сделать проще?

Как оказалось, хорошо, что я задал вопрос с картинками заранее, потому что выяснилось, что картинки вообще не нужно никуда отдельно сохранять, они загружаются напрямую в Ozon по API и Claude это торжественно написал: 

✴️ Claude:

Отлично, вот теперь у меня есть критическая информация. Главное открытие: Ozon API принимает файлы напрямую через multipart/form-data, никакие публичные ссылки не нужны! Метод POST /v1/product/certificate/create принимает поле files (массив байтов, расширения jpg/jpeg/png/pdf) — то есть мы заливаем сертификат прямо файлом в теле запроса. Хостинг картинок не нужен в принципе.

Потом Claude задал несколько уточняющих вопросов и выдал финальный (на тот момент) пайплайн: 

папка → пары файлов → Ollama (qwen3-vl:8b) → Ozon API  ├─ POST /v1/product/certificate/create (оба листа в одном сертификате)  ├─ POST /v2/product/list (один раз для всех артикулов: offer_id → product_id)  └─ POST /v1/product/certificate/bind (привязка по product_id)  └─ CSV-отчёт с тем, что сделано

Далее он подготовил скрипт, написал мне какие-то команды для терминала, но как я не пытался его запустить, у меня ничего не получилось. И через несколько таких диалогов, я решил сдаться и признаться Клоду и вам: 

👨🏻‍💻 Я:

так, я ничего не понял 
что мне надо сделать чтобы запустить этот скрипт по шагам

И дальше пошло все хорошо — он начал расписывать мне по шагам, даже слишком примитивным, типа «как открыть терминал на Mac». И на каждом шаге просил выполнить в терминале проверки, чтобы не сбиться с пути. Хоть и долго и стыдно, но зато все запустилось, и я по ходу дела уже разобрался в этих терминальских путях и командах. 

Этап 3. Исправить все ошибки

С первого раза как обычно ничего не заработало, поэтому потребовалось очень много итераций ошибок -> копирования их в Клод -> доработки скрипта -> и так по кругу. По пути вскрывались более глобальные ошибки, например: 

  • Одни сертификаты связаны по названию файла, другие нет — можно понять связь только по номеру самого сертификата внутри, а это значит, что нужно больше времени на парсинг 

  • В названиях файлов тупо есть опечатки, из-за которых нельзя корректно их опознать и связать 

  • У каких-то сертификатов есть приложения с артикулами, у каких-то нет — артикулы содержаться прямо в сертификате 

Все подобные ошибки ломают простой скрипт и заставляют писать сложный, на который еще и потратится больше времени и ресурсов. Клод конечно с ними справился и наконец получилось выполнить тестовый прогон и спарсить несколько сертификатов.

НО! Я в очередной раз решил быть откровенным и написал Клоду: 

👨🏻‍💻 Я:

блин давай сделаем все проще 
в ozon надо отправить по одному файлу сертификата + связанным приложениям в один метод добавления сертификата 
а товаров внутри может быть сколько угодно, можно максимум ограничить их под соотвествующий бренд
остальное пусть они сами сверяют

Коллеги из Ozon, извините. Но пришлось переложить часть работы на вас. 

В итоге Клод полностью переписал скрипт на новый, более простой и требующий меньше ресурсов от Ollama. Как он мне написал: 

✴️ Claude:

Это сразу даёт в 2-4 раза меньше времени на прогон. На твоих 225 парах + ~6 многостраничных — раньше распознавание заняло бы ~5+ часов, теперь ~2-3.

Там возникла новая проблема с маппингом брендов, потому что в Ozon они имеют разные названия даже на товарах одного и того же бренда (но это уже другая моя боль) — получилось обойтись простым json, в котором название папки соотносится сразу с несколькими названиями, например: 

{ "Boker": ["Boker", "Boker Plus", "Magnum by Boker", "Magnum"]  }

Этап 4. Подготовиться к тестовому прогону

Когда локально мы прошли все тесты, пришло время подключать Ozon Seller API. «Ради безопасности» Клод попросил создать .env файл с ключами:

cat > .env << 'EOF'OZON_CLIENT_ID=44604OZON_API_KEY=ВПИШИ_СЮДА_НОВЫЙ_КЛЮЧEOF

А потом попросил открыть блокнот, вписать и сохранить ключ через него:

open -a TextEdit .env

Сами Client ID и API ключ можно найти и сгенерировать в Ozon Seller -> Профиль -> Настройки -> Seller API

Еще несколько кругов ада ошибок и исправлений и получился рабочий скрипт! Скрипт связал сертификат с приложением к сертификату -> Ollama спарсила данные сертификатов -> Фотографии сертификатов и параметры из него отправились в Ozon Seller по API. Проверяем и видим результат: 

Этап 5. Запустить полный прогон 

Запустил боевой скрипт и ушел по делам на 3 часа. Вернулся и красота: 

Финальное ревью от Claude:

✴️ Claude:

🎉🎉🎉 Получилось! Полный прогон отработал успешно. Давай разбираться по итогам.

Итоги
Распознавание сертификатов: 3 часа 23 минуты, 231 сертификат, средняя скорость 52 сек/серт.
Загрузка в Ozon: 34 минуты, 231 сертификат загружен, к каждому привязаны товары соответствующего бренда.
Не удалось распознать: всего 3 сертификата (Cold Steel 16760, SOG 14450, SOG 17452 — на них Ollama зависла даже с ретраями). Это менее 1.3% — отличный результат.

Осталось дождаться прохождение модерации от Ozon. В итоге, с помощью Claude и Ollama я смог (если модерация пройдет успешно) восстановить продажи +1000 товаров, загрузив +200 сертификатов всего за день. Раньше мне бы потребовалось на эту работу несколько месяцев, а то и год.

Используемая модель в Claude: Opus 4.7


Спасибо, что прочитали до конца! Как вы поняли из статьи, я не сильно разбираюсь в коде, поэтому буду ждать конструктивные комментарии по улучшению процесса — где можно сделать проще, где я жестко тупанул, а где вообще написал полную чушь.

А если вы также как я, ничего не смыслите в программировании, но хотите создавать свои продукты, приглашаю почитать мою старую статью про создание бота для Телеграма через Cursor, а также подписаться на мой микро телеграм-канал, где я писал про разработку iOS-приложения через Cursor и его публикацию в AppStore с нуля: https://t.me/com_murzak

ссылка на оригинал статьи https://habr.com/ru/articles/1030234/