Important

You are browsing documentation for version 5.1 of OroCommerce, supported until March 2026. Read the documentation for version 6.0 (the latest LTS version) to get up-to-date information.

See our Release Process documentation for more information on the currently supported and upcoming releases.

Import Product Information 

Hint

This section is part of the Data Import concept guide topic that provides guidelines on import operations in Oro applications.

The Import File option helps import a large bulk of product information into the product catalog using the .csv file.

Import Products 

Example of a product bulk import template

sku

attributeFamily.code

status

type

inventory_status.id

primaryUnitPrecision.unit.code

primaryUnitPrecision.precision

primaryUnitPrecision.conversionRate

primaryUnitPrecision.sell

additionalUnitPrecisions:0:unit:code

additionalUnitPrecisions:0:precision

additionalUnitPrecisions:0:conversionRate

additionalUnitPrecisions:0:sell

names.default.value

shortDescriptions.default.value

descriptions.default.value

featured

metaDescriptions.default.value

slugPrototypes.default.value

category.default.title

Kit Items

sku_001

default_family

enabled

simple

in_stock

kg

3

1

1

item

0

5

1

Product Name

Product Short Description

system

1

defaultMetaDescription

lumen-item

Category Name

sku_002

default_family

enabled

kit

out_of_stock

set

3

1

1

set

0

5

1

Product Name

Product Short Description

system

1

defaultMetaDescription

touchscreen-pos-system

Category Name

id=,label=“Additional Unit”,optional=false,products=sku_001,min_qty=,max_qty=,unit=item id=,label=“Base Unit”,optional=true,products=sku_001|sku_002,min_qty=1,max_qty=2,unit=item

To import a bulk of product information:

  1. In the main menu, navigate to Products > Products. The product list opens.

  2. Click Import File on the top right.

  3. Prepare data for import: Create your bulk information in the .csv format. Once your file is ready, click Choose File, select the prepared comma-separated values (.csv) file, and click Import File.

Note

Ensure that your .csv file is saved in the Unicode (UTF-8) encoding. Otherwise, the content of the file can be rendered improperly.

The steps that are necessary to perform to import the products successfully
  1. Validate import results: Click Validate to check your import results. If there are any Records with errors, fix them in the .csv file before starting the import.

  2. Launch import: After successful validation, click Import File.

  3. Click Cancel to decline the import.

Important

Interactive status messages inform about the import progress, and once the import is complete, the changes are reflected in the list upon refresh. An email message with the import status is also delivered to your mailbox.

Product Kit Data 

Note

Product Kits in the back-office are available as of 5.1LTS. Product Kits in the storefront are available as of 5.1.3. By default, the product kits feature is disabled for v.5.1 but you can enable it with developer assistance in the yaml file of the ProductBundle.

The following formats of kitItems are possible (with or without the ID parameter):

id=43,label=“Barcode Scanner”,optional=false,products=6VC22|4PJ19|7TY55,min_qty=1,max_qty=1,unit=item
label=“Receipt Printer(s)”,optional=true,products=8DO33,min_qty=1,max_qty=,unit=item

If any additional custom parameters are added, a validation error will occur.

Depending on the ID and whether the product already exists in the Oro application, different logic may be required to import products from kitItems.

  • A new product and kitItems with empty IDs will create a new product with new kitItems.

  • A new product and kitItems with IDs will create a new product with new kitItems (ignoring kitItems IDs).

  • An existing product in Oro and kitItems with empty IDs will update the product and replace the entire kitItems collection.

  • An existing product in Oro and kitItems with IDs belonging to this product will update the product with kitItems.

  • An existing product in Oro and kitItems with IDs that do not belong to this product will result in a validation error.

The type of data that can be used as value for the provided parameters:

  • ID is optional. Allowed values are empty or integer.

  • label is a mandatory field. Allowed values are non-empty string. It is recommended to use double quotes (e.g., “Base unit”). Although it is not mandatory for a simple label, using quotes is preferable to ensure correct functionality. If special characters like quotes are required in the label, you must use quotes and escape, e.g., label=”,My, =Escaped= "Kit" 'Item'”.

  • optional is optional. The default value is false. Allowed values are true, false, yes, no, 1, 0.

  • products is mandatory. SKU of products should be listed separated by a delimiter |.

  • min_qty, max_qty are optional. The default value is empty (null). Allowed values are expected empty value or float (1, 0, 1.0, 0.0). Integer values are converted to float. Float must use a dot as a decimal separator, as using a comma will result in an error.

  • unit is mandatory. A validation error will occur if no unit code is provided.

Import Product Images 

Make sure to upload the image files for the related products to the appropriate location according to the configuration of the import_product_images Gaufrette filesystem. By default, it is configured to use the {PROJECT}/var/data/import_files local directory as storage.

Then, fill the table with the name of the image file, the SKU name of the product, and a place for the image to be displayed, where 1 is display and 0 is do not display.

If you are running your application on OroCloud, please be aware that before proceeding with the product images upload via the UI (the process which assigns images to products and makes them available in the asset library), you need to:

  1. Upload all your images to OroCloud using FTP/SFTP.

  2. Follow the step outlined in the Media Upload cloud documentation to move the uploaded images to the appropriate folder before starting product images import.

Example of a product images import template

SKU

Name

Main

Listing

Additional

sku_001

001.jpg

1

0

1

To import a bulk of product images:

  1. In the main menu, navigate to Products > Products. The product list opens.

  2. Click Import File on the top right.

  3. In the Import dialog, select the Product Images tab.

  4. Click Choose File and select the .csv file you prepared.

The steps that are necessary to perform to import the product price attributes successfully
  1. Click Download Import Template to download a sample .csv file with the necessary headers.

  2. Prepare data for import: Create your bulk information in the .csv format based on the downloaded file.

Once your file is ready, click Choose File and select the prepared comma-separated values (.csv) file.

  1. Validate import results: Click Validate to check your import results. If there are any Records with errors, fix them in the .csv file before starting the import.

  2. Launch import: After successful validation, click Import File.

  3. Click Cancel to decline the import.

Import Product Price Attributes Data 

Example of a product price attributes data import template

Product SKU

Price Attribute

Unit Code

Currency

Price

sku_001

MSRP/MAP

item

USD

20

To import a bulk of product price attributes:

  1. In the main menu, navigate to Products > Products. The product list opens.

  2. Click Import File on the top right.

  3. In the Import dialog, select the Price Attributes Data tab.

  4. Click Choose File and select the .csv file you prepared.

Note

Ensure that your .csv file is saved in the Unicode (UTF-8) encoding. Otherwise, the content of the file can be rendered improperly.

The steps that are necessary to perform to import the product price attributes successfully
  1. Click Download Import Template to download a sample .csv file with the necessary headers.

  2. Prepare data for import: Create your bulk information in the .csv format based on the downloaded file. Once your file is ready, click Choose File and select the prepared comma-separated values (.csv) file.

  3. Select the strategy for uploading the file:

    • Add and Replace strategy overrides the existing price attribute data (MAP/MSRP/etc.) with the one mentioned in the file for the corresponding product item. Also, it adds the price attribute data to the products with empty values.

    • Reset and Add strategy removes the existing price attribute values for all the products (regardless of the currency) if the price attribute is listed in the file. For example, if an MSRP value is provided for Product A, all the MSRP values in all the currencies are removed for all the products. If MAP is not mentioned in the file, the MAP values remain intact.

      As an illustration, let us fill the table with the following information:

      Product SKU

      Price Attribute

      Unit Code

      Currency

      Price

      TAG1

      MSRP

      item

      USD

      20

      Initially, the TAG1 item and all other items on the Product page have some MSRP attribute price.

      Once we imported the .csv file, all the MSRP attribute prices were deleted, and the TAG1 item acquired a new MSRP price of 20 USD instead of the previous 7 USD.

      View the results of the products import via the Reset and Add import strategy
  4. Validate import results: Click Validate to check your import results. If there are any Records with errors, fix them in the .csv file before starting the import.

  5. Launch import: After successful validation, click Import File.

  6. Click Cancel to decline the import.

Important

Interactive status messages inform about the import progress, and once the import is complete, the changes are reflected in the list upon refresh. An email message with the import status is also delivered to your mailbox.