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

时间:2016-11-05 11:32:12

标签: jsp localization jstl number-systems

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

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

如何以这种方式本地化号码系统?例如。当使用Marathi语言环境时,拉丁语数字456应打印为456。

3 个答案:

答案 0 :(得分:2)

马拉

不幸的是,Marathi没有标准的实施方式。但您可以使用ICU RuleBasedNumberFormat创建自己的翻译。

还有一个GitHub project,用于格式化马拉地语数字,因此您不需要自己编写the rules。您可以轻松扩展它以处理多种语言并为其创建自定义标记。

印地文

印地语得到了Java NumberFormat的支持,但fmt:numberFormat并未直接使用它,因此您仍需要创建自定义标记。

答案 1 :(得分:0)

如果您只想将您的Numbers转换为Marathi等效数字。 然后创建如下所示的类。本课程可以帮助您将您的数字转换为不仅仅是马拉地语,还有旁遮普语,古吉拉特语,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非常容易使用这些代码。

如果您使用过滤器,那么<​​/ p>

//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") }

答案 2 :(得分:-1)

应使用<fmt:numberFormat>格式化数字。请参阅J2EE tutorial中的示例。