亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

java.text.Collat??or 將“v”和“w”視為瑞典語言/區域設置的相同字母

java.text.Collat??or 將“v”和“w”視為瑞典語言/區域設置的相同字母

BIG陽 2022-06-30 11:47:00
以下測試在 Java 8 中正確通過。Comparator<String> stringComparator = Collator.getInstance(new Locale("sv", "SE"));Assert.assertTrue(stringComparator.compare("aaaa", "bbbb") < 0);Assert.assertTrue(stringComparator.compare("waaa", "vbbb") < 0);Assert.assertTrue(stringComparator.compare("vaaa", "wbbb") < 0);此令waaa前前后后。vbbb_ 顯然它將和視為同一個字母。vaaawbbbvw事實上,根據維基百科,在瑞典語中:到 2006 年,由于新的外來詞,“W”的使用量有所增加,因此“W”正式成為字母,“V”=“W”的排序規則已被棄用。2006 年以前的書籍和軟件通常使用該規則。該規則被棄用后,一些書籍和軟件繼續應用它。有沒有人對此有一般的解決方法,以便在瑞典語言環境v中w被視為單獨的字母?
查看完整描述

3 回答

?
小唯快跑啊

TA貢獻1863條經驗 獲得超2個贊

創建您自己的RuleBasedCollator。

檢查返回的字符串的值

((RuleBasedCollator)Collator.getInstance(new Locale("sv", "SE"))).getRules()

并修改它以滿足您的需求,然后使用您修改的規則創建一個新的整理器。

并且可能也提交一份 JDK 錯誤報告,這是一個很好的衡量標準。


查看完整回答
反對 回復 2022-06-30
?
料青山看我應如是

TA貢獻1772條經驗 獲得超8個贊

這將 waaa 置于 vbbb 之前,將 vaaa 置于 wbbb 之前。顯然它將 v 和 w 視為同一個字母。

即使在瑞典語言環境中,JDK 也確實不會將 'w' 和 'v' 視為相同的字符。字母“v”出現在“w”之前。

Assert.assertEquals(1, stringComparator.compare("w", "v"));//TRUE

但是,根據瑞典的排序規則,JDK 將 'wa' 排序在 'vb' 之前。

Assert.assertEquals(1, stringComparator.compare("wa", "vb"));//FALSE


查看完整回答
反對 回復 2022-06-30
?
12345678_0001

TA貢獻1802條經驗 獲得超5個贊

您可以創建一個自定義比較器,它包裝整理器并手動處理v您w想要的方式。


我對此做了兩個實現。


第一個簡短而優雅,它使用 Guavaslexicographical比較器以及 Holger 在評論中提供的棘手的正則表達式。


private static final Pattern VW_BOUNDARY = Pattern.compile("(?=[vw])|(?<=[vw])", Pattern.CASE_INSENSITIVE);


public static Comparator<String> smallCorrectVwWrapper(Comparator<Object> original) {

    return Comparator.comparing(

        s -> Arrays.asList(VW_BOUNDARY.split((String) s)),

        Comparators.lexicographical(original));

第二個實現是一個大而復雜的事情,它做同樣的事情,但是手動實現,沒有庫和正則表達式。


public static Comparator<String> correctVwWrapper(Comparator<Object> original) {

    return (s1, s2) -> compareSplittedVw(original, s1, s2);

}


/**

 * Compares the two string by first splitting them into segments separated by W

 * and V, then comparing the segments one by one.

 */

private static int compareSplittedVw(Comparator<Object> original, String s1, String s2) {

    List<String> l1 = splitVw(s1);

    List<String> l2 = splitVw(s2);


    int minSize = Math.min(l1.size(), l2.size());


    for (int ix = 0; ix < minSize; ix++) {

        int comp = original.compare(l1.get(ix), l2.get(ix));

        if (comp != 0) {

            return comp; 

        }

    }


    return Integer.compare(l1.size(), l2.size());

}


private static boolean isVw(int ch) {

    return ch == 'V' || ch == 'v' || ch == 'W' || ch == 'w';

}



/**

 * Splits the string into segments separated by V and W.

 */

public static List<String> splitVw(String s) {

    var b = new StringBuilder();


    var result = new ArrayList<String>();


    for (int offset = 0; offset < s.length();) {

        int ch = s.codePointAt(offset);


        if (isVw(ch)) {

            if (b.length() > 0) {

                result.add(b.toString());

                b.setLength(0);

            }


            result.add(Character.toString((char) ch));

        } else {

            b.appendCodePoint(ch);

        }


        offset += Character.charCount(ch);

    }


    if (b.length() > 0) {

        result.add(b.toString());

    }


    return result;

}

用法:


public static void main(String[] args) throws Exception {

    Comparator<String> stringComparator = correctVwWrapper(Collator.getInstance(new Locale("sv", "SE")));


    System.out.println(stringComparator.compare("a", "z") < 0);     // true

    System.out.println(stringComparator.compare("wa", "vz") < 0);   // false

    System.out.println(stringComparator.compare("wwa", "vvz") < 0); // false

    System.out.println(stringComparator.compare("va", "wz") < 0);   // true

    System.out.println(stringComparator.compare("v", "w") < 0);     // true

}

實現一個 wrapping 需要做更多的工作Collator,但它不應該太復雜。


查看完整回答
反對 回復 2022-06-30
  • 3 回答
  • 0 關注
  • 162 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號