This is one of the entries for a contest in freelancer.com.
ShopifySharp was used to create this console application.
Since the rate of using the Shopify API for free account is 2 calls/second, I'd come up with this solution on how to import the products in the fastest way possible:
- Get the shop info to get the primary location id. (used 1 API call)
- Select all distinct categories from the database.
- Get all smart collections on the Shopify store. (used 1 API call for every 250 items)
- Split all categories NOT yet imported into the Shopify store, and use these categories for building rules for the new smart collection -- this will automatically assign the products according to their tags (I assume that the product tag must be equal to all of the split categories). Then, add the new smart collection to the Shopify store. (used 1 API call for every smart collection added)
- From the database, select all products NOT yet imported into the Shopify store.
- For each product item in the retrieved products:
- Assume lost Internet connection during the last import, check the first item if it is already added (if it has the same product title). If it is already added, proceed to Substep vii. (used 1 API call)
- Assign its product variant info to the new product variant.
- Assign its product image info to the new product image.
- Split its product category, and assign them to the tag of the new product.
- Assign the new product image and the new product variant to the new product.
- Add the new product to the Shopify store (used 1 API call for every product added).
- Set the new inventory item, and assign the product item quantity, shop primary location id, and product variant inventory item id. (used 1 API call for every inventory item set).
- Insert the added product into the separated table of the database. (I assume this process means that the product is already imported into the Shopify store)
- Repeat Step 6 until all products added. All products are automatically assigned to their corresponding smart collection/s.
NOT considering internet connection speed, with 1,000 new products with 20 new categories, the number of API calls will be:
Procedure | No. of API Calls |
---|---|
Getting the shop info | 1 |
Getting all smart collections | 1 |
Adding new smart collections | 20 |
Adding new products | 1,000 |
Setting all inventory items* | 1,000 |
Total | 2,022 |
Duration: 1,011 seconds
With 2 API calls/second, all 1,000 products will be imported within roughly 17 minutes.
*After August 1st, apps will no longer be able to set inventory using
inventory_quantity
orinventory_quantity_adjustment
. --Product Variant. Retrieved 2018-07-12.
*After August 1, 2018, apps will no longer be able to use the ProductVariant API to adjust inventory. Additionally, fulfillments and refunds with restocks will require a location_id at creation. --Migrating to multi-location inventory. Retrieved 2018-07-12.