Android國際化資源文件自動化生成工具

一、工具起源

       

       如果在做一個產品的過程當中,可能會涉及到多個apk的開發,而且要求實現多國語言。而這些apk可能會由多人分工共同完成。但如果這樣的話,每個人都需要整理各自apk所要顯示的文字交給專人來翻譯。專人負責收集和翻譯文字,翻譯完了之後再交給每個開發者。比如這個產品中的所有apk都需要支持10國語言,也就是說每個開發人員,要拿着翻譯好的文字,在各自負責的項目中創建這10個語種的資源文件,並且將這10個語種的文字依次放入到不同語種目錄下的資源文件中。而且當apk寫完後,後續有修改,並在界面上添加了新的文字顯示,又需要翻譯,並要修改各國語言的資源文件。可想而知這是一件多麼煩鎖的事情。。。(負責翻譯的人要收集所有文字,整理並翻譯,開發人拿到翻譯後的文字之後,要修改各個語言下的資源文件抓狂)!所以爲了管理方便,由一個人負責收集所有apk中需要翻譯的所有文字,並統一交給負責翻譯的人。最後拿到翻譯後的文字,用一個工具來統一管理並生成所有apk所需要的各國語言的資源文件,這樣是不是很爽呢??那是肯定的。不但能減少團隊成員之間的工作量,還能提高工作效率。下面將介紹一下這個工具的使用,希望日後你也遇到類似的項目,對你有所有幫助。


二、國際化實現方式


實現Android國際化,分爲兩步:

1、在工程的res目錄下創建不同國家和語種的資源目錄(values或drawable),系統會根據設備當前的語言環境自動選擇相應的資源文件。

2、翻譯各國語言的文字,放入不同國家和語句的資源目錄,即strings.xml或arrays.xml。


三、工具實現原理介紹


1、準備一個存放各個apk各國語言文字的excel模板文件。模板數據格式說明:

1> 每個sheet代表一個apk

2> sheet中的第一列存放strings.xml或arrays.xml文件中的id

          3> 第二列存放默認文字(當設備找不到當前語言的文字時,使用默認的)

          4> 第三列存放各個國家的語言縮寫(列名使用語言縮寫,比如中文:cn)



5>   sheet命名注意:

a、生成strings.xml文件:直接用模塊名即可,如:MusicPlayer

b、生成arrays.xml文件:用模塊名+_arrays,如:MusicPlayer_arrays

2、使用Apache的開源框架POI解析excel讀取各個apk的語言文字,並通過dom4j生成strings.xml和arrays.xml


四、工具類源代碼


1、生成資源文件工具類

[java] view plaincopy
  1. package com.i18n.i18nbuilder;  
  2.   
  3. import java.io.File;  
  4. import java.io.FileInputStream;  
  5. import java.io.FileOutputStream;  
  6. import java.io.InputStream;  
  7. import java.util.ArrayList;  
  8. import java.util.List;  
  9.   
  10. import org.apache.poi.hssf.usermodel.HSSFCell;  
  11. import org.apache.poi.hssf.usermodel.HSSFRow;  
  12. import org.apache.poi.hssf.usermodel.HSSFSheet;  
  13. import org.apache.poi.hssf.usermodel.HSSFWorkbook;  
  14. import org.apache.poi.ss.usermodel.Cell;  
  15. import org.apache.poi.ss.util.CellRangeAddress;  
  16. import org.dom4j.Document;  
  17. import org.dom4j.DocumentHelper;  
  18. import org.dom4j.Element;  
  19. import org.dom4j.io.OutputFormat;  
  20. import org.dom4j.io.XMLWriter;  
  21.   
  22. import com.mltsagem.i18nbuilder.model.ArrayEntity;  
  23. import com.mltsagem.i18nbuilder.model.StringEntity;  
  24.   
  25. /** 
  26.  * 讀取EXCEL語言模板文件,生成各個國家語言的資源文件 
  27.  * @author yangxin 
  28.  */  
  29. public class ResourcesBuilder {  
  30.       
  31.     public static final String DEFAULT_LANGUAGE_FLAG = "values";  
  32.       
  33.     /** 
  34.      * 各個國家的語言 
  35.      */  
  36.     public static final String[] LANGUAGE = {  
  37.         DEFAULT_LANGUAGE_FLAG,  
  38.         "en-rGB","de-rDE","fr-rFR","es-rES","it-rIT","pt-rPT","nl-rNL","sv-rSE","no-rNO",  
  39.         "fi-rFI","da-rDK","hu-rHU","pl-rPL","cs-rCZ","tr-rTR","ru-rRU","el-rGR","ro-rRO"  
  40.     };   
  41.       
  42.     // 讀取需要生成strings.xml的sheet  
  43.     public static final String[] STRINGS_SHEETS = {  
  44.         "MusicPlayer",  
  45.         "VideoPlayer"  
  46.     };  
  47.       
  48.     // 讀取需要生成arrays.xml的sheet  
  49.     public static final String[] ARRAYS_SHEETS = {  
  50.         "MusicPlayer",  // 讀取MusicPlayer_arrays sheet中的數據  
  51.         //"VideoPlayer"  
  52.     };  
  53.       
  54.     /** 
  55.      * 資源文件生成的臨時目錄 
  56.      */  
  57.     public static final String I18N_TEMP_DIR = "/tmp/i18n/";  
  58.       
  59.     /** 
  60.      * 語言文件夾前綴 
  61.      */  
  62.     public static final String RESOURCES_DIR_PREFIX = "values-";  
  63.       
  64.     /** 
  65.      * 資源文件名 
  66.      */  
  67.     public static final String STRING_RESOURCES_FILE_NAME = "strings.xml";  
  68.     public static final String ARRAY_RESOURCES_FILE_NAME = "arrays.xml";  
  69.   
  70.     public static void main(String[] args) {  
  71.         try {  
  72.             String file = "/Users/yangxin/Desktop/language.xls";  
  73.             // 清除以前生成的文件和目錄  
  74.             clearDir(new File(I18N_TEMP_DIR));  
  75.             // 創建語言文件夾  
  76.             createI18nDir();  
  77.             // 生成各個模塊中各個國家的strings.xml語言資源文件  
  78.             builderStringResources(new FileInputStream(file));  
  79.             // 生成各個模塊中各個國家的arrays.xml語言資源文件  
  80.             builderArrayResources(new FileInputStream(file));  
  81.             System.out.println("全部生成成功:" + I18N_TEMP_DIR);  
  82.         } catch (Exception e) {  
  83.             e.printStackTrace();  
  84.         }  
  85.     }  
  86.       
  87.     /** 
  88.      * 創建語言文件夾 
  89.      */  
  90.     public static void createI18nDir() {  
  91.         for (int i = 0; i < STRINGS_SHEETS.length; i++) {  
  92.             // 創建模塊所對應的目錄  
  93.             File parent = new File(I18N_TEMP_DIR,STRINGS_SHEETS[i]);  
  94.             parent.mkdirs();  
  95.             // 創建各個國家語言的資源目錄  
  96.             for (int j = 0; j < LANGUAGE.length; j++) {  
  97.                 String language = null;  
  98.                 if (j == 0) {  
  99.                     language = LANGUAGE[j];  
  100.                 } else {  
  101.                     language = RESOURCES_DIR_PREFIX + LANGUAGE[j];  
  102.                 }  
  103.                 File file = new File(parent,language);  
  104.                 if (!file.exists()) {  
  105.                     file.mkdirs();  
  106.                 }  
  107.             }  
  108.         }  
  109.     }  
  110.       
  111.     /** 
  112.      * 生成strings.xml資源文件 
  113.      */  
  114.     public static void builderStringResources(InputStream is) throws Exception {  
  115.         HSSFWorkbook book = new HSSFWorkbook(is);  
  116.         for (int i = 0; i < STRINGS_SHEETS.length; i++) {  
  117.             HSSFSheet sheet = book.getSheetAt(book.getSheetIndex(STRINGS_SHEETS[i]));  
  118.             System.out.println("build strings for " + sheet.getSheetName());  
  119.             int rowNum = sheet.getLastRowNum();  
  120.             for (int j = 0; j < LANGUAGE.length; j++) {  
  121.                 String language = LANGUAGE[j];  
  122.                 ArrayList<StringEntity> stringEntitys = new ArrayList<StringEntity>();  
  123.                 File dir = null;  
  124.                 if (DEFAULT_LANGUAGE_FLAG.equals(language)) {   // 創建默認語言  
  125.                     dir = new File(I18N_TEMP_DIR + STRINGS_SHEETS[i] + File.separator + language);  
  126.                 } else {  
  127.                     dir = new File(I18N_TEMP_DIR + STRINGS_SHEETS[i] + File.separator + RESOURCES_DIR_PREFIX + language);  
  128.                 }  
  129.                 File file = new File(dir,STRING_RESOURCES_FILE_NAME);  
  130.                 for (int k = 1; k <= rowNum; k++) {  
  131.                     HSSFRow row = sheet.getRow(k);  
  132.                     if (row.getLastCellNum() < 1)  
  133.                         continue;  
  134.                     String resId = row.getCell(0).getStringCellValue().trim();          // resId  
  135.                     HSSFCell cell = row.getCell(j+1);  
  136.                     String value = null;  
  137.                     if (cell != null) {  
  138.                         value = cell.getStringCellValue();          // 某一個國家的語言  
  139.                         if (value == null || "".equals(value.trim())) {  
  140.                             continue;  
  141.                         }  
  142.                         StringEntity entity = new StringEntity(resId, value.trim());  
  143.                         stringEntitys.add(entity);  
  144.                     }  
  145.                 }  
  146.                 // 創建資源文件  
  147.                 builderStringResources(stringEntitys,file);  
  148.             }  
  149.         }  
  150.         is.close();  
  151.         System.out.println("------------------strings.xml資源文件生成成功!------------------");  
  152.     }  
  153.       
  154.     private static void builderStringResources(List<StringEntity> stringEntitys,File file) throws Exception {  
  155.         OutputFormat format = OutputFormat.createPrettyPrint();  
  156.         format.setEncoding("utf-8");  
  157.         XMLWriter writer = new XMLWriter(new FileOutputStream(file),format);  
  158.         Document document = DocumentHelper.createDocument();  
  159.         Element root = document.addElement("resources");  
  160.         for (StringEntity stringEntity : stringEntitys) {  
  161.             Element stringElement = root.addElement("string");  
  162.             stringElement.addAttribute("name", stringEntity.getResId());  
  163.             stringElement.setText(stringEntity.getValue());  
  164.         }  
  165.         writer.write(document);  
  166.         writer.close();  
  167.     }  
  168.       
  169.     /** 
  170.      * 生成arrays.xml資源文件 
  171.      */  
  172.     public static void builderArrayResources(InputStream is) throws Exception {  
  173.         HSSFWorkbook book = new HSSFWorkbook(is);  
  174.         for (int i = 0; i < ARRAYS_SHEETS.length; i++) { // 功能模塊  
  175.             HSSFSheet sheet = book.getSheetAt(book.getSheetIndex(ARRAYS_SHEETS[i]+"_arrays"));  
  176.             System.out.println("build arrays for " + sheet.getSheetName());  
  177.             int rowNum = sheet.getNumMergedRegions();   // sheet.getLastRowNum();  
  178.             for (int j = 0; j < LANGUAGE.length; j++) {      // 語言  
  179.                 String language = LANGUAGE[j];  
  180.                 ArrayList<ArrayEntity> arrayEntities = new ArrayList<ArrayEntity>();  
  181.                 File dir = null;  
  182.                 if (DEFAULT_LANGUAGE_FLAG.equals(language)) {   // 創建默認語言  
  183.                     dir = new File(I18N_TEMP_DIR + ARRAYS_SHEETS[i] + File.separator + language);  
  184.                 } else {  
  185.                     dir = new File(I18N_TEMP_DIR + ARRAYS_SHEETS[i] + File.separator + RESOURCES_DIR_PREFIX + language);  
  186.                 }  
  187.                 File file = new File(dir,ARRAY_RESOURCES_FILE_NAME);  
  188.                 for (int k = 1; k <= rowNum; k++) {  
  189.                     CellRangeAddress range = sheet.getMergedRegion(k-1);  
  190.                     int mergedRows = range.getNumberOfCells();  
  191.                     int lastRow = range.getLastRow();  
  192.                     int rowIndex = (lastRow - mergedRows) + 1;  
  193.                     String resId = sheet.getRow(rowIndex).getCell(0).getStringCellValue().trim();           // resId  
  194.                     ArrayEntity entity = new ArrayEntity(resId);  
  195.                     ArrayList<String> items = new ArrayList<String>();  
  196.                     for (int z = rowIndex; z <= lastRow; z++) {  
  197.                         HSSFCell cell = sheet.getRow(z).getCell(j+1);  
  198.                         String value = getValue(cell);  
  199.                           
  200.                         if (value == null || "".equals(value.trim())) { // 如果該語言沒有對應的翻譯,默認使用英語  
  201.                             HSSFCell defaultCell = sheet.getRow(z).getCell(1);  
  202.                             value = getValue(defaultCell);  
  203.                         }  
  204.                           
  205.                         if ("temp".equalsIgnoreCase(value.trim())) {  
  206.                             continue;  
  207.                         }  
  208.                           
  209.                         items.add(value);  
  210.                     }  
  211.                     entity.setItems(items);  
  212.                     arrayEntities.add(entity);  
  213.                 }  
  214.                 // 創建資源文件  
  215.                 builderArrayResources(arrayEntities,file);  
  216.             }  
  217.         }  
  218.         System.out.println("------------------arrays.xml資源文件生成成功!------------------");  
  219.     }  
  220.       
  221.     /** 
  222.      * 獲取單元格的值 
  223.      * @param cell 單元格 
  224.      * @return 單元格對應的值 
  225.      */  
  226.     private static String getValue(HSSFCell cell) {  
  227.         String value = "";  
  228.         if (cell != null) {  
  229.             switch (cell.getCellType()) {  
  230.             case Cell.CELL_TYPE_NUMERIC:  
  231.                 value = String.valueOf((int)cell.getNumericCellValue()).trim();  
  232.                 break;  
  233.             case Cell.CELL_TYPE_STRING:  
  234.                 value = cell.getStringCellValue().trim();   
  235.                 break;  
  236.             case Cell.CELL_TYPE_BOOLEAN:  
  237.                 value = String.valueOf(cell.getBooleanCellValue()).trim();  
  238.                 break;  
  239.             default:  
  240.                 value = cell.getStringCellValue().trim();   
  241.                 break;  
  242.             }  
  243.         }  
  244.         return value;  
  245.     }  
  246.       
  247.     private static void builderArrayResources(ArrayList<ArrayEntity> arrayEntities, File file) throws Exception {  
  248.         OutputFormat format = OutputFormat.createPrettyPrint();  
  249.         format.setEncoding("utf-8");  
  250.         XMLWriter writer = new XMLWriter(new FileOutputStream(file),format);  
  251.         Document document = DocumentHelper.createDocument();  
  252.         Element root = document.addElement("resources");  
  253.         for (ArrayEntity arrayEntity : arrayEntities) {  
  254.             Element arrayElement = root.addElement("string-array");  
  255.             arrayElement.addAttribute("name", arrayEntity.getName());  
  256.             List<String> items = arrayEntity.getItems();  
  257.             for (String item : items) {  
  258.                 Element itemElement = arrayElement.addElement("item");  
  259.                 itemElement.setText(item);  
  260.             }  
  261.         }  
  262.         writer.write(document);  
  263.         writer.close();  
  264.     }  
  265.   
  266.     /** 
  267.      * 清除以前生成的文件和目錄 
  268.      */  
  269.     public static void clearDir(File dir) {  
  270.         if (!dir.exists()) return;  
  271.         File[] files = dir.listFiles();  
  272.         for (File file : files) {  
  273.             if (file.isDirectory()) {  
  274.                 clearDir(file);  
  275.             } else {  
  276.                 file.delete();  
  277.             }  
  278.         }  
  279.         dir.delete();  
  280.     }  
  281. }  

[java] view plaincopy
  1. package com.i18n.i18nbuilder.model;  
  2.   
  3. import java.util.List;  
  4.   
  5. public class ArrayEntity {  
  6.   
  7.     private String name;  
  8.     private List<String> items;  
  9.       
  10.     public ArrayEntity() {  
  11.         super();  
  12.     }  
  13.     public ArrayEntity(String name) {  
  14.         super();  
  15.         this.name = name;  
  16.     }  
  17.     public ArrayEntity(String name, List<String> items) {  
  18.         super();  
  19.         this.name = name;  
  20.         this.items = items;  
  21.     }  
  22.     public String getName() {  
  23.         return name;  
  24.     }  
  25.     public void setName(String name) {  
  26.         this.name = name;  
  27.     }  
  28.     public List<String> getItems() {  
  29.         return items;  
  30.     }  
  31.     public void setItems(List<String> items) {  
  32.         this.items = items;  
  33.     }  
  34.       
  35. }  
[java] view plaincopy
  1. package com.i18n.i18nbuilder.model;  
  2.   
  3. public class StringEntity {  
  4.       
  5.     private String resId;  
  6.     private String value;  
  7.     public StringEntity() {  
  8.         super();  
  9.     }  
  10.     public StringEntity(String resId, String value) {  
  11.         super();  
  12.         this.resId = resId;  
  13.         this.value = value;  
  14.     }  
  15.     public String getResId() {  
  16.         return resId;  
  17.     }  
  18.     public void setResId(String resId) {  
  19.         this.resId = resId;  
  20.     }  
  21.     public String getValue() {  
  22.         return value;  
  23.     }  
  24.     public void setValue(String value) {  
  25.         this.value = value;  
  26.     }  
  27. }  

2、解析資源文件(strings.xml/arrays.xml)中ID和value的工具類(解決手工複製id和value到excel模板中的問題)

[java] view plaincopy
  1. package com.i18n.i18nbuilder;  
  2. import java.io.FileInputStream;  
  3. import java.io.InputStream;  
  4. import java.util.List;  
  5.   
  6. import org.dom4j.Attribute;  
  7. import org.dom4j.Document;  
  8. import org.dom4j.Element;  
  9. import org.dom4j.io.SAXReader;  
  10.   
  11. /** 
  12.  * 解析strings.xml和array.xml字符串資源文件,獲取資源文件中的鍵和值 
  13.  * @author yangxin 
  14.  */  
  15. public class ParseStringResources {  
  16.       
  17.     public static void main(String[] args) {  
  18.         try {  
  19.             getStringsIds();  
  20.             getArraysIds();  
  21.         } catch (Exception e) {  
  22.             e.printStackTrace();  
  23.         }  
  24.     }  
  25.       
  26.     public static void getStringsIds() throws Exception {  
  27.         System.out.println("-------------------MusicPlayer----------------------------");  
  28.         ParseStringResources.parseStringsResourcesKey(new FileInputStream("musicplayer_strings.xml"));      // 解析id  
  29.         ParseStringResources.parseStringsResourcesValue(new FileInputStream("musicplayer_strings.xml"));    // 解析value  
  30.           
  31.         System.out.println("-------------------VideoPlayer----------------------------");  
  32.         ParseStringResources.parseStringsResourcesKey(new FileInputStream("video_strings.xml"));  
  33.         ParseStringResources.parseStringsResourcesValue(new FileInputStream("video_strings.xml"));  
  34.     }  
  35.       
  36.     public static void getArraysIds() throws Exception {  
  37.         InputStream is = null;  
  38.         is = new FileInputStream("musicplayer_arrays.xml");  
  39.         ParseStringResources.parseArraysResources(is);  
  40.     }  
  41.       
  42.     /** 
  43.      * 解析strings.xml中的key 
  44.      */  
  45.     public static void parseStringsResourcesKey(InputStream is) throws Exception {  
  46.         SAXReader saxReader = new SAXReader();  
  47.         Document document = saxReader.read(is);  
  48.         Element rootElement = document.getRootElement();  
  49.         List<Element> elements = rootElement.elements();  
  50.         for (Element element : elements) {  
  51.             String resid = element.attribute("name").getValue();  
  52.             System.out.println(resid);  
  53.         }  
  54.         System.out.println("-----------------------------------key解析完成---------------------------------");  
  55.     }  
  56.       
  57.     /** 
  58.      * 解析strings.xml中的value 
  59.      */  
  60.     public static void parseStringsResourcesValue(InputStream is) throws Exception {  
  61.         SAXReader saxReader = new SAXReader();  
  62.         Document document = saxReader.read(is);  
  63.         Element rootElement = document.getRootElement();  
  64.         List<Element> elements = rootElement.elements();  
  65.         for (Element element : elements) {  
  66.             String text = element.getTextTrim();  
  67.             System.out.println(text);  
  68.         }  
  69.         System.out.println("-----------------------------------value解析完成---------------------------------");  
  70.     }  
  71.       
  72.     /** 
  73.      * 解析arrays.xml文件 
  74.      */  
  75.     public static void parseArraysResources(InputStream is) throws Exception {  
  76.         SAXReader saxReader = new SAXReader();  
  77.         Document document = saxReader.read(is);  
  78.         Element rootElement = document.getRootElement();  
  79.         List<Element> elements = rootElement.elements();  
  80.         for (Element element : elements) {  
  81.             Attribute attribute = element.attribute("name");  
  82.             if (attribute == nullcontinue;  
  83.             String resid = attribute.getValue();  
  84.             System.out.println(resid);  
  85.             List<Element> items = element.elements();  
  86.             for (Element item : items) {  
  87.                 String text = item.getTextTrim();  
  88.                 System.out.println("      " + text);  
  89.             }  
  90.         }  
  91.     }  
  92. }  
3、各國語言縮寫映射關係

[html] view plaincopy
  1. <?xml version="1.0" encoding="UTF-8"?>  
  2. <date_formats>  
  3.     <date_format>  
  4.         <language>cs</language>  
  5.         <format>dd.M.yyyy</format>  
  6.         <english>Czech</english>  
  7.         <chinese>捷克文</chinese>  
  8.     </date_format>  
  9.     <date_format>  
  10.         <language>da</language>  
  11.         <format>dd-MM-yyyy</format>  
  12.         <english>Deutsch</english>  
  13.         <chinese>丹麥文</chinese>  
  14.     </date_format>  
  15.     <date_format>  
  16.         <language>de</language>  
  17.         <format>dd.MM.yyyy</format>  
  18.         <english>German</english>  
  19.         <chinese>德文</chinese>  
  20.     </date_format>  
  21.     <date_format>  
  22.         <language>en</language>  
  23.         <format>dd/MM/yyyy</format>  
  24.         <english>English</english>  
  25.         <chinese>英文</chinese>  
  26.     </date_format>  
  27.     <date_format>  
  28.         <language>es</language>  
  29.         <format>dd/MM/yyyy</format>  
  30.         <english>Spanish</english>  
  31.         <chinese>西班牙文</chinese>  
  32.     </date_format>  
  33.     <date_format>  
  34.         <language>fr</language>  
  35.         <format>dd/MM/yyyy</format>  
  36.         <english>French</english>  
  37.         <chinese>法文</chinese>  
  38.     </date_format>  
  39.     <date_format>  
  40.         <language>it</language>  
  41.         <format>dd/MM/yyyy</format>  
  42.         <english>Italian</english>  
  43.         <chinese>意大利文</chinese>  
  44.     </date_format>  
  45.     <!--沒有-->  
  46.     <date_format>  
  47.         <language>hu</language>  
  48.         <format>yyyy.MM.dd</format>  
  49.         <english>Hungarian</english>  
  50.         <chinese>匈牙利文</chinese>  
  51.     </date_format>  
  52.     <date_format>  
  53.         <language>nl</language>  
  54.         <format>dd-M-yyyy</format>  
  55.         <english>Dutch</english>  
  56.         <chinese>荷蘭文</chinese>  
  57.     </date_format>  
  58.     <!-- 沒有 android.mk也沒有-->  
  59.     <date_format>  
  60.         <language>no</language>  
  61.         <format>dd.MM.yyyy</format>  
  62.         <english>Norwegian</english>  
  63.         <chinese>挪威文</chinese>  
  64.     </date_format>  
  65.     <date_format>  
  66.         <language>pl</language>  
  67.         <format>yyyy-MM-dd</format>  
  68.         <english>Polish</english>  
  69.         <chinese>波蘭文</chinese>  
  70.     </date_format>  
  71.     <date_format>  
  72.         <language>pt</language>  
  73.         <format>dd-MM-yyyy</format>  
  74.         <english>Portuguese</english>  
  75.         <chinese>葡萄牙文</chinese>  
  76.     </date_format>  
  77.     <!--沒有-->  
  78.     <date_format>  
  79.         <language>ro</language>  
  80.         <format>dd.MM.yyyy</format>  
  81.         <english>Romanian</english>  
  82.         <chinese>羅馬尼亞文</chinese>  
  83.     </date_format>  
  84.     <!--沒有-->  
  85.     <date_format>  
  86.         <language>fi</language>  
  87.         <format>dd.M.yyyy</format>  
  88.         <english>Finnish</english>  
  89.         <chinese>芬蘭文</chinese>  
  90.     </date_format>  
  91.     <date_format>  
  92.         <language>sv</language>  
  93.         <format>yyyy-MM-dd</format>  
  94.         <english>Swedish</english>  
  95.         <chinese>瑞典文</chinese>  
  96.     </date_format>  
  97.     <date_format>  
  98.         <language>tr</language>  
  99.         <format>dd.MM.yyyy</format>  
  100.         <english>Turkish</english>  
  101.         <chinese>土耳其文</chinese>  
  102.     </date_format>  
  103.     <date_format>  
  104.         <language>el</language>  
  105.         <format>dd/M/yyyy</format>  
  106.         <english>Greece</english>  
  107.         <chinese>希臘文</chinese>  
  108.     </date_format>  
  109.     <date_format>  
  110.         <language>ru</language>  
  111.         <format>dd.MM.yyyy</format>  
  112.         <english>Russian</english>  
  113.         <chinese>俄文</chinese>  
  114.     </date_format>  
  115.     <date_format>  
  116.         <language>zh</language>  
  117.         <format>yyyy-M-dd</format>  
  118.         <english>Chinese</english>  
  119.         <chinese>中文</chinese>  
  120.     </date_format>  
  121. </date_formats>  

五、資源文件生成效果


1、控制檯打印信息

2、資源文件存放目錄及strings.xml內容


工具使用注意事項:

1>、sheet的命名必須和工具類中”STRINGS_SHEETS“和”ARRAYS_SHEETS“數組存儲的元素名稱保持一致(區分大小寫)

2>、刪除sheet中的空白單元格

3>、修改languages.xls模板文件和資源文件生成後的存放路徑


相關資源下載地址:

項目源代碼 語言文字Excel模板


轉自:http://blog.csdn.net/xyang81/article/details/8945701

發佈了16 篇原創文章 · 獲贊 3 · 訪問量 5萬+
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章