Currently in development. Goal is to eventually have ChatGPT nicely translate all dialogue when given an RPGMaker JSON file. Right now its only tested on MV but hopeful to add more engines in the future.
- API Key: https://platform.openai.com/account/api-keys
- Organization Key: https://platform.openai.com/account/org-settings
- Python3: https://www.python.org/downloads/
- Add your API key and Organization Key to a .env file. An example can be found in the repo.
- Add a prompt.txt file using prompt.example as a template. (See ChatGPT Prompt Section)
- Untranslated JSON files go in
/files
. Anything translated will end up in/translated
- Run the script either with VSCode or by running .\main.py in a CLI.
prompt.txt
will decide what and how ChatGPT translates the text. This is where you can customize it's output. This is extremely useful for when ChatGPT gives you a translation that you don't want. You can use this to tell him what to do, give examples of how you want things translated, etc. The example included is what I use currently, but you should tailor it to the game you are trying to translate.
Note that the bigger the prompt, the more $$$ its going to cost to translate.
In its current state, you will very likely run into errors. There hasn't been enough testing with enough games to get it in a stable state. Often ChatGPT won't know how to translate something and will timeout. Currently the timeout is pretty long so the program may hang for a while. NEVER CLOSE THE PROGRAM FORCEFULLY unless you wish to lose your translation data, which might as well be you losing money.
If the ChatGPT times out or hits any other error, what has already been translated will always be saved as long as you let it fail on its own. The file will still be placed in /translated on success or fail. That way you don't have to worry about the program failing and you wasting money on bugs.
- Go into ChatGPT Playground https://platform.openai.com/playground?mode=chat and enter the text it failed on. If it comes out clean, likely the prompt may just need some adjusting or the string may need to be formatted in some way.
- Create an example for that specific text. At the bottom of prompt.txt are examples you can enter which will give the AI training data on how to translate. This pretty much works 100% of the time but the downside is it will make your prompt.txt file bigger and your translation more expensive.
- Unsure what causes this. I recommend you just let it fail on its own and give you the error message. The error handler will tell you what line of text threw the error and what error it received.
You'll need VSCode or something similar:
- Place a breakpoint on this line
return [response.choices[0].message.content, response.usage.total_tokens]
and run the code in debugging mode. Everytime a request comes back you should be able to view the response object to see what text got translated and what the response was.