vortexasdk.endpoints.products
Try me out in your browser:
Products
Products(self)
Products endpoint.
load_all
Products.load_all()
Load all products.
search
Products.search(
term: typing.Union[str, typing.List[str], NoneType] = None,
ids: typing.Union[str, typing.List[str], NoneType] = None,
product_parent: typing.Union[str, typing.List[str], NoneType] = None,
exact_term_match: bool = False,
filter_layer: typing.Optional[str] = None)
Find all products matching given search terms.
Arguments
-
term: The name(s) (or partial name(s)) of a product we'd like to search
ids: ID or IDs of products we'd like to search
product_parent: ID, or list of IDs of the immediate product parent. E.g.
product_parent ='12345'
will return all children of product12345
.exact_term_match: By default, the SDK returns all products which name includes the search term. For example, searching for "Gasoil" will return results including "Gasoil", "Gasoil 0.4pc", "Gasoil 500ppm" etc. Setting
exact_term_match
to true ensure that only exact term matches are returned, ie just "Gasoil" in this case.filter_layer: Must be one of product types ['group', 'group_product', 'category', 'grade'].
Returns
List of products matching the search arguments.
Examples
Let's look for products with in one of ['diesel', 'fuel oil', 'grane']
their name, or related names.
>>> from vortexasdk import Products
>>> df = Products().search(term=['diesel', 'fuel oil', 'grane']).to_df('all')
Returns
id | name | layer.0 | leaf | parent.0.name | parent.0.layer.0 | parent.0.id | meta.api_min | meta.api_max | ref_type | meta.sulphur_min | meta.sulphur_max | |
---|---|---|---|---|---|---|---|---|---|---|---|---|
0 | 1c107b4317bc2c8... | Fuel Oil | category | False | Dirty products | product | 5de0b00094e0fd... | 12.8878 | 12.8878 | product | nan | nan |
1 | fddedd17e02507f... | Grane | grade | True | Medium-Sour | subproduct_group | a7e26956fbb917... | 29.2955 | 29.2955 | product | 0.62 | 0.62 |
2 | deda35eb9ca56b5... | Diesel/Gasoil | category | False | Clean products | product | b68cbb7746f8b9... | 35.9556 | 35.9556 | product | nan | nan |
Further Documentation
reference
Products.reference(id: str)
Perform a product lookup.
Arguments
- id: Product ID to lookup
Returns
Product record matching the ID
Further Documentation:
vortexasdk.endpoints.products_result
ProductResult
ProductResult(*, records: typing.List,
reference: typing.Dict[str, typing.Any])
Container class that holds the result obtained from calling the Product
endpoint.
model_config
to_list
ProductResult.to_list()
Represent products as a list.
to_df
ProductResult.to_df(
columns:
typing.Union[typing_extensions.Literal['all'], typing.List[str], NoneType] = ['id', 'name', 'layer.0', 'parent.0.name']
)
Represent products as a pd.DataFrame
.
Arguments
- columns: The product features we want in the dataframe. Enter
columns='all'
to include all features. Defaults tocolumns = ['id', 'name', 'layer.0', 'parent.0.name']
.
Returns
pd.DataFrame
of products.