Large_dataset_translator
Large_dataset_translator copied to clipboard
Translate large dataset to any language with google translation api and multithreads processing, no key required!
Large Dataset Translator
The Large Dataset Translator is a robust solution crafted to effectively translate sizable datasets into diverse languages. It provides a smooth and parallelized translation process, guaranteeing swift outcomes without the need for an API key. The tool facilitates multithreaded processing, allowing users to translate extensive datasets in significantly less time. Additionally, it features an automatic fail-restart mechanism, ensuring the seamless continuation of the translation process in case of any interruptions.
Features
-
Parallelized Translation: Utilizes multithread processing to split large datasets into chunks and translate in parallel, significantly reducing processing time.
-
Handling Large Lists: Efficiently handles datasets containing large lists (e.g., dialogs) by splitting them into sub-lists and translating each sub-list in parallel.
-
Automatic Retry Mechanism: Any thread that fails during translation will automatically restart with its specific chunk until all data points are fully translated.
-
Data Format Compatibility: Converts datasets into a format supported by pyarrow and huggingface-datasets for seamless integration.
-
Pre-Translation Filters: Filters can be applied before translation, such as removing examples that might contain code.
-
GIL Resilience: Python Global Interpreter Lock (GIL) won't affect speed, as tasks consist of purely I/O-bound operations.
-
Automatic Download: Automatically downloads the converted dataset and the translated dataset on Colab upon completion.
-
Unlimited Translation: No API key is required, making it ideal for translating large datasets without limitations.
Demonstration
Here's a demo of the DataParser class, translating 1507 rows of text to Korean in under 2 minutes:
The translation split logic:
Setup
Local Machine
git clone https://github.com/vTuanpham/Large_dataset_translator.git
cd Large_dataset_translator
# Set up virtual environment
virtualenv trans-env
# Activate virtual environment
source trans-env/bin/activate
# Install required packages
pip install -r requirements.txt
Google Colab
!git clone https://github.com/vTuanpham/Large_dataset_translator.git
%cd Large_dataset_translator
%pip install -r requirements.txt
Testing
Run the provided test script to ensure the tool works correctly. This should take about 10-20 minutes on a local machine or 5-10 minutes on Colab.
Local Machine:
python examples/YahmaAlpaca/AlpacaCleaned_Parser.py
Colab data:image/s3,"s3://crabby-images/e7985/e79852128a5f83c92496b9d734ca52d01e009a39" alt="Open In Colab"
%run examples/YahmaAlpaca/AlpacaCleaned_Parser.py
Check the examples/YahmaAlpaca directory when the script finished, there should be a parsed dataset and a vietnamese dataset.
Usage
To translate your own dataset:
-
Inherit the DataParser class and implement your read and convert logic.
-
Ensure the convert function maps all fields from the original dataset to those in configs/base_config.py, or choose other configs that fit your dataset.
-
Set do_translate=True in the super call to enable translation.
def __init__(self, file_path: str, output_path: str): super().__init__(file_path, output_path, parser_name=PARSER_NAME, do_translate=True, no_translated_code=True, target_lang="ko")
-
Customize translation settings such as target language and pre-translation filters.
Pull requests are welcome for new dataset conversion examples 😎
Supported Languages
The tool supports translation into a wide array of languages. Refer to the table in google's documentation for the complete list. https://cloud.google.com/translate/docs/languages
Known Issues
- 'TypeError: "NoneType' object is not iterable" This issue is relevant to gender-specific translation, you can read more here https://github.com/ssut/py-googletrans/issues/260