Building an automated Android Localization Tool today

Building an automated Android Localization Tool today

March 28, 2019ยท
Nishant Srivastava
<h5>TL;DR: I used Google Sheets + Translate + AppScript to build a completely free and robust Automated Android Localization Tool! ๐Ÿผ<span class="hx-absolute -hx-mt-20" id="tldr-i-used-google-sheets--translate--appscript-to-build-a-completely-free-and-robust-automated-android-localization-tool-"></span> <a href="#tldr-i-used-google-sheets--translate--appscript-to-build-a-completely-free-and-robust-automated-android-localization-tool-" class="subheading-anchor" aria-label="Permalink for this section"></a></h5>

So this started when I found the below tweet:

Basically what it is doing is that using Google Sheets you can specify a cell text to be translated to another language using the very simple formula as below:

GOOGLETRANSLATE(text, [source_language, target_language])

Read more here.

I was curious so I just tried it out on my own Google Sheet:


Direct link to the google sheet file: Google Translate In Sheets

<p>Testing English, Spanish, Hindi, Tamil, German, Korean, Russian, Czech, Estonian, French, Polish, Chinese</p>

…and it totally worked!! ๐ŸŽ‰

I only have to duplicate a row (each column has the formula already set up to translate the text in the first column to respective columns language) and then update the text in the first column in English with my own string value. That English string is translated to all the other languages in their respective columns.

This was super cool and I was mostly done here. This was a cool feature. However, if you remember my first tweet, I mentioned:

<p>Seems super handy for indie Android devs when considering simple localization!</p>

One guy reached out to me about that end result and how to do that:

img

Interestingly that is what most people would like. The first thing that pops up in the head that one can use the Google App Script to parse the data in Google Sheets and then it is just a matter of formatting the data to be the right format of how strings.xml is.

So I went on to fiddle with some Google AppScript and was able to generate the below: strings.xml @Pastebin.com

Hmm, pretty close now ๐Ÿค”

What is missing, is that each of these needs to be in its own value-lang folder inside a strings.xml file.

Should be easy. So after fiddling a bit more I was able to end up generating the full folder structure inside my own Google Drive folder.

img

Finally! ๐ŸŽˆ

Everything was so quick to bootstrap and get running ๐Ÿ›ด

I plan on open sourcing this sheet and the app script by this weekend. It is not doing anything complex, pretty simple. I would also release the script as an addon so it is easier to set up for people.

For now, I think it works for most Indie devs who cannot afford to pay for translation services and hopefully it will be as helpful as I think it is.

Stay tuned for more updates here (about open-sourcing the script, addon release and explanation about how the script )๐Ÿ™ƒ

For now, I am too sleepy to write anything ๐Ÿ˜ด

Until next time, keep crushing code ๐Ÿ˜Ž

<p>Special Credit to <a href="https://twitter.com/JakeMillerTech" target="_blank" rel="noopener">Jake Millar</a> who tweeted the Google Translate trick inside Google Sheets!</p>

I do a lot of such tinkering with scripts and Android development over at Github, or you can see me rambling about tech in twitter :]

Last updated on