Requires: WooCommerce 3.0.9 or newer
Automatically generate a SKU for parent / simple products, variations, or both when the product is published or updated.
IMPORTANT: The SKU field will be disabled for SKUs being generated by the plugin. Your own previously created SKUs will be overridden if you update a product while generating SKUs, and they will change if you change your product slug (while using this to generate them). Be sure you want to complete automate SKUs if you leave this enabled all of the time.
You can also selectively enable and disable the plugin if you don’t want to override existing SKUs when saving products. You can view product documentation for help.
SKUs for simple, external, or parent products can be generated from the product’s slug (hyphenated name) or ID. For example, a product with the slug
wp-tee-shirt can have a SKU of
192 (whatever the product’s ID is). This SKU will be generated any time the product is published or updated.
If the product is a variable product, this plugin can also generate SKUs for the product variations if desired (these typically inherit the parent SKU). Variation SKUs can either append attribute slugs or variation IDs for each variation to the parent SKU.
Here are some samples of different SKU formats that can be created with this plugin.
You can also manually set simple / parent SKUs, or manually set the variation SKUs, if you don’t want the plugin to generate them for you.
This plugin provides options to:
- automatically generate simple / parent product SKUs when the product is published or updated
- generate simple / parent product SKUs using the product slug or ID
- automatically generate SKUs for product variations when the product is published or updated
- generate variation SKUs using the attribute slugs or variation ID
- use the bulk product update action to easily force SKU generation for more than one product — handy to bulk-generate SKUs for products created before installing this plugin
SKUs for all product types
The WooCommerce Product SKU generator lets you determine which SKUs should be generated automatically, and whether these SKUs should use product slugs or IDs. If a SKU is generated, the input for that SKU will be disabled since you cannot adjust it.
If you choose not to generate a SKU, then you can enter your own SKU. For example, if you only generate variation SKUs, then you can enter a parent product SKU. This will be used as the base for your generated variation SKUs, and slugs or IDs will be appended to it.
If you only create parent / simple SKUs, you will be able to manually create your own variation SKUs, as these will not be overridden by saving or updating a product.
You can bulk add SKUs to products that you’ve created prior to installing this plugin. If you select the products you want to update, then bulk edit them, all you have to do is hit “Update”. When the products are saved, SKUs will be generated for all products.
This action will also automatically generate the SKUs for product variations if you have them enabled.
- See the product page for full details and documentation
- View more of SkyVerge’s free WooCommerce extensions
- View all WooCommerce extensions from SkyVerge
The plugin text domain is:
By default, if you have an attribute name with a space (such as “Burnt Marshmallow” for color), the SKU will use this exact formatting. A SKU for this variation would look like:
If you enable the setting to replace spaces, this will instead look like:
parentSKU-Burnt-Marshmallow — depending on which setting you’ve chose. This is helpful if your external fulfillment service does not allow spaces in SKUs.
In very rare cases, you may find that variation SKUs do not sort attributes in the same order. For example, one variation may be
tee-shirt-large-black, and another could be
If this occurs, you can force attributes to sort themselves consistently before generating the SKU, which will resolve this problem. You could also consider this for new installations.
Be sure you want to enable this if you have existing SKUs, as variation SKUs that were generated previously could be overridden while updating a product – they’ll be re-generated with the forced attribute order.
To force attribute sorting, add this code snippet where you add your site modifications, such as a custom plugin or theme’s functions.php:
add_filter( 'wc_sku_generator_force_attribute_sorting', '__return_true' );
NOTE that any time a product is updated, its SKU will be generated, so this may override old SKUs if you update products. This plugin is meant for complete SKU automation, or you can selectively enable / disable it as needed.
Be sure you’re running WooCommerce 2.5+ in your shop.
- upload the entire
woocommerce-product-sku-generatorfolder to the
- upload the .zip file with the plugin under Plugins > Add New > Upload, or
- Search for “WooCommerce Product SKU Generator” under Plugins > Add New
- upload the entire
Activate the plugin through the Plugins menu in WordPress
Click the “Configure” plugin link or go to WooCommerce > Settings > Products and scroll down to the “Product SKUs”. Select which SKUs you’d like to generate and what should be used to generate them.
If you generate variation SKUs with slugs, determine if spaces in attribute names should be replaced with underscores instead.
View documentation on the product page for more help if needed.