如何在Java中本地化数字系统,例如印地语或马拉地语



我使用带有属性文件的JSTL <fmt:message>标记来本地化JSP上的文本。不同语言的文本保存在与键相关联的各自的属性文件中。

然后该键在JSP中使用,如<fmt:message key="somekey"/>

我如何用这种方式定位数字系统?例如,当使用马拉地语言环境时,拉丁数字456应打印为४५६。

马拉地语

遗憾的是,没有马拉地语的标准实现。但是你可以使用ICU的RuleBasedNumberFormat来创建你自己的翻译。

还有一个GitHub项目,用它来格式化马拉地数字,这样你就不需要自己写规则了。您可以很容易地扩展它来处理多种语言,并为它创建一个自定义标记。

印地语

Hindi由Java的NumberFormat支持,但fmt:numberFormat不直接使用它,因此您仍然需要创建自定义标记

如果您只是想将您的数字转换为马拉地等效数字。然后创建如下所示的类。这门课不仅可以帮助你把你的数字转换成马拉地语,还可以转换成旁遮普语,古吉拉特语,hundi语,还有乌尔都语。

HashMap<String, String> unicodeConversionList = new HashMap<>();
public void prepareList(String lang)
{
    unicodeConversionList.clear();
    if("marathi".equalsIgnoreCase(lang))
    {
        unicodeConversionList.put("0", "u0966");
        unicodeConversionList.put("1", "u0967");
        unicodeConversionList.put("2", "u0968");
        unicodeConversionList.put("3", "u0969");
        unicodeConversionList.put("4", "u096A");
        unicodeConversionList.put("5", "u096B");
        unicodeConversionList.put("6", "u096C");
        unicodeConversionList.put("7", "u096D");
        unicodeConversionList.put("8", "u096E");
        unicodeConversionList.put("9", "u096F");
    }
    else if("hindi".equalsIgnoreCase(lang))
    {
        unicodeConversionList.put("0", "u0966");
        unicodeConversionList.put("1", "u0967");
        unicodeConversionList.put("2", "u0968");
        unicodeConversionList.put("3", "u0969");
        unicodeConversionList.put("4", "u096A");
        unicodeConversionList.put("5", "u096B");
        unicodeConversionList.put("6", "u096C");
        unicodeConversionList.put("7", "u096D");
        unicodeConversionList.put("8", "u096E");
        unicodeConversionList.put("9", "u096F");
    }else if("gujarati".equalsIgnoreCase(lang))
    {
        unicodeConversionList.put("0", "u0AE6");
        unicodeConversionList.put("1", "u0AE7");
        unicodeConversionList.put("2", "u0AE8");
        unicodeConversionList.put("3", "u0AE9");
        unicodeConversionList.put("4", "u0AEA");
        unicodeConversionList.put("5", "u0AEB");
        unicodeConversionList.put("6", "u0AEC");
        unicodeConversionList.put("7", "u0AED");
        unicodeConversionList.put("8", "u0AEE");
        unicodeConversionList.put("9", "u0AEF");
    }else if("punjabi".equalsIgnoreCase(lang))
    {
        unicodeConversionList.put("0", "u0AE6");
        unicodeConversionList.put("1", "u0AE7");
        unicodeConversionList.put("2", "u0AE8");
        unicodeConversionList.put("3", "u0AE9");
        unicodeConversionList.put("4", "u0AEA");
        unicodeConversionList.put("5", "u0AEB");
        unicodeConversionList.put("6", "u0AEC");
        unicodeConversionList.put("7", "u0AED");
        unicodeConversionList.put("8", "u0AEE");
        unicodeConversionList.put("9", "u0AEF");
    }else if("urdu".equalsIgnoreCase(lang))
    {
        unicodeConversionList.put("0", "u06F0");
        unicodeConversionList.put("1", "u06F1");
        unicodeConversionList.put("2", "u0682");
        unicodeConversionList.put("3", "u0693");
        unicodeConversionList.put("4", "u06A4");
        unicodeConversionList.put("5", "u06B5");
        unicodeConversionList.put("6", "u06C6");
        unicodeConversionList.put("7", "u06D7");
        unicodeConversionList.put("8", "u06E8");
        unicodeConversionList.put("9", "u06F9");
    }else{
        unicodeConversionList.put("0", "0");
        unicodeConversionList.put("1", "1");
        unicodeConversionList.put("2", "2");
        unicodeConversionList.put("3", "3");
        unicodeConversionList.put("4", "4");
        unicodeConversionList.put("5", "5");
        unicodeConversionList.put("6", "6");
        unicodeConversionList.put("7", "7");
        unicodeConversionList.put("8", "8");
        unicodeConversionList.put("9", "9");
    }
}
public String convertToMarathi(String lang,String str)
{
    prepareList(lang);
    StringBuilder response = new StringBuilder("");
    if(str!=null && str.trim().length()>0 && unicodeConversionList.size()==10)
        for (int i = 0; i < str.length(); i++)
        {
            String temp = "" + str.charAt(i);
            if (unicodeConversionList.containsKey(temp))
                response.append(unicodeConversionList.get(temp));
            else
                response.append(temp);
        }
    else
        response.append(str);
    return response.toString();
}

EL一起使用这些代码非常容易。

如果使用过滤器,则

//Add This code to your filters
public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) throws IOException,
        ServletException
{
    HttpServletRequest req = (HttpServletRequest) request;
    if (req.getSession().isNew())
    {
        HttpSession session=req.getSession();
        session.setAttribute("converter", new ConverterUtil());
    }
    // pass the request along the filter chain
    chain.doFilter(request, response);
}

然后在JSP中你需要做的就是

${converter.convertToMarathi("Gujarati","1234 u 567 z 890") }

如果你想在每一页手动书写,请遵循下面的代码

<jsp:useBean id="converter2" class="digimation.bestowBucket.util.ConverterUtil"></jsp:useBean>
${converter2.convertToMarathi("maRatHi","1234 u 567 z 890") }

数字应该使用<fmt:numberFormat>格式化。参见J2EE教程中的示例。

最新更新