Library that converts and downloads multilingual data stored in xlsx files into a JSON directory structure, and vice versa. The directory structure is tailored to the i18next library.
Supports direct execution via npx commands. It also supports importing from browser and Node environments.
When converting to a JSON directory, you can choose whether to compress to a zip file. It's also possible in reverse.
You can choose whether to create an index.js/ts file for importing multilingual data into your project.
Create a template xlsx file to get you started easily.
Examples of commands that can be executed directly from the terminal include the following.
Without auto-compressing/extracting JSON directory and auto-generating index.js:
npx i18n-xlsx-to-json-directory template-xlsx -d ./template_i18n.xlsx
npx i18n-xlsx-to-json-directory xlsx-to-json-zip -s ./template_i18n.xlsx -d ./i18n.zip --export-file-type js
npx i18n-xlsx-to-json-directory json-zip-to-xlsx -s ./i18n.zip -d ./i18n.xlsx
With auto-compressing/extracting JSON directory auto-generating index.ts:
npx i18n-xlsx-to-json-directory template-xlsx -d ./template_i18n.xlsx
npx i18n-xlsx-to-json-directory xlsx-to-json-zip -s ./template_i18n.xlsx -d ./i18n --export-file-type ts --auto-extract
npx i18n-xlsx-to-json-directory json-zip-to-xlsx -s ./i18n -d ./i18n.xlsx --auto-compress
Create and save template xlsx files.
-d, --destination: The path on which the converted file will be stored.
After converting the xlsx file into a json directory structure, compress it to create and download a zip file.
-s, --source: The path to import the file you want to convert.
-d, --destination: The path on which the converted file will be stored.
--auto-extract: Automatically decompress converted zip files. You must specify a directory in the -d option.
--export-file-type: Creates a default index script file that exports each language and namespace.('js' || 'ts' || undefined)
After analyzing the zip file, create and download the xlsx file.
-s, --source: The path to import the file you want to convert.
-d, --destination: The path on which the converted file will be stored.
--auto-compress: Automatically compresses and converts the selected directory. You must specify a directory in the -d option.
Import the library into the script file as follows.
import {
createTemplateXlsx,
convertXlsxToJsonZip,
convertJsonZipToXlsx,
} from 'i18n-xlsx-to-json-directory/browser';
Create and save template xlsx files.
After converting the xlsx file into a json directory structure, compress it to create and download a zip file.
exportFileType: Creates a default index script file that exports each language and namespace.('js' || 'ts' || undefined)
After analyzing the zip file, create and download the xlsx file.
Import the library into the script file as follows.
import {
createTemplateXlsx,
convertXlsxToJsonZip,
convertJsonZipToXlsx,
} from 'i18n-xlsx-to-json-directory/node';
Create and save template xlsx files.
After converting the xlsx file into a json directory structure, compress it to create and download a zip file.
autoExtract: Automatically decompress converted zip files. You must specify a directory in the -d option.
exportFileType: Creates a default index script file that exports each language and namespace.('js' || 'ts' || undefined)
After analyzing the zip file, create and download the xlsx file.
autoCompress: Automatically compresses and converts the selected directory. You must specify a directory in the -d option.
You can fix the problem by referring to the SheetJS library website.
Pull requests are always welcome. For major changes, please open an issue first to discuss what you would like to change.
Please make sure to update tests as appropriate.