Skip to content

methods

ProductMethods

Bases: SellerApiABCMethods

list_attributes async

Python
1
list_attributes(iter_: bool = True, limit: int = 1000, dir_='DESC', **kwargs: Unpack[ListAttributesFilter]) -> list[Product]

Получить список аттрибутов товара.

Аргументы:

  • dir_ (по умолчанию "desc") - направление сортировки
  • iter_ (по умолчанию True) - необходимо ли получать все объекты, итерируясь по страницам
  • limit (по умолчанию 1000) - максимальное количество объектов, которое будет получено за один запрос
  • offer_id (опционально) - Фильтр по параметру offer_id. Можно передавать список значений.
  • product_id (опционально) - Фильтр по параметру product_id. Можно передавать список значений.
  • visibility (опционально - Фильтр по видимости товара (Visibility

Возвращает: list[Product]

Source code in marketplace_apis/ozon/product/methods.py
Python
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
async def list_attributes(
        self,
        iter_: bool = True,
        limit: int = 1000,
        dir_="DESC",
        **kwargs: Unpack[ListAttributesFilter],
) -> list[Product]:
    """
    Получить список аттрибутов товара.
    # Аргументы:
    * dir_ (по умолчанию "desc") - направление сортировки
    * iter_ (по умолчанию True) - необходимо ли получать все объекты,
    итерируясь по страницам
    * limit (по умолчанию 1000) - максимальное количество объектов, которое будет
    получено за один запрос
    * offer_id (опционально) - Фильтр по параметру offer_id.
    Можно передавать список значений.
    * product_id (опционально) - Фильтр по параметру product_id.
    Можно передавать список значений.
    * visibility (опционально - Фильтр по видимости товара
    ([Visibility](enums.md#ozon.product.enums.Visibility)

    # Возвращает: list[[Product](product.md)]
    """

    raw_products = []

    async def make_request(last_id=None):
        resp, decoded_resp = await self.client.post(
            API_PATH["list_product_attributes"],
            data={
                     "limit": limit,
                     "sort_dir": dir_,
                     "filter": kwargs,
                 }
                 | ({"last_id": last_id} if last_id else {}),
        )
        nonlocal raw_products
        raw_products += decoded_resp["result"]
        return resp, decoded_resp

    _, data = await make_request()
    while iter_ and data["last_id"]:
        _, data = await make_request(data["last_id"])

    return [Product.from_dict(raw_product) for raw_product in raw_products]

list_info async

Python
1
list_info(offer_id: list[str] | None = None, product_id: list[int] | None = None, sku: list[int] | None = None) -> list[Product]

Получить список информации о товарах.

Аргументы:

  • offer_id - (опционально) список offer_id, по которым требуется получить информацию (list[str])
  • product_id - (опционально) список product_id, по которым требуется получить информацию (list[int])
  • sku - (опционально) список sku, по которым требуется получить информацию (list[int])

Возвращает: list[Product]

Source code in marketplace_apis/ozon/product/methods.py
Python
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
async def list_info(
        self,
        offer_id: list[str] | None = None,
        product_id: list[int] | None = None,
        sku: list[int] | None = None,
) -> list[Product]:
    """
    Получить список информации о товарах.
    # Аргументы:
    * offer_id - (опционально) список offer_id, по которым требуется получить
    информацию (list[str])
    * product_id - (опционально)  список product_id, по которым требуется получить
    информацию (list[int])
    * sku - (опционально) список sku,  по которым требуется получить информацию
    (list[int])

    # Возвращает: list[[Product](product.md)]
    """
    _, data = await self.client.post(
        API_PATH["list_product_info"],
        data={
            "offer_id": offer_id,
            "product_id": product_id,
            "sku": sku,
        },
    )
    return [
        Product.from_dict(raw_product) for raw_product in data["result"]["items"]
    ]