Use RuleBasedCollator : Collator « I18N « Java Tutorial






/*
 * Copyright (c) 1995 - 2008 Sun Microsystems, Inc.  All rights reserved.
 *
 * Redistribution and use in source and binary forms, with or without
 * modification, are permitted provided that the following conditions
 * are met:
 *
 *   - Redistributions of source code must retain the above copyright
 *     notice, this list of conditions and the following disclaimer.
 *
 *   - Redistributions in binary form must reproduce the above copyright
 *     notice, this list of conditions and the following disclaimer in the
 *     documentation and/or other materials provided with the distribution.
 *
 *   - Neither the name of Sun Microsystems nor the names of its
 *     contributors may be used to endorse or promote products derived
 *     from this software without specific prior written permission.
 *
 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS
 * IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO,
 * THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
 * PURPOSE ARE DISCLAIMED.  IN NO EVENT SHALL THE COPYRIGHT OWNER OR
 * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
 * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
 * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
 * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF
 * LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
 * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
 * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
 */

import java.text.Collator;
import java.text.ParseException;
import java.text.RuleBasedCollator;

public class RulesDemo {

  public static void sortStrings(Collator collator, String[] words) {
    String tmp;
    for (int i = 0; i < words.length; i++) {
      for (int j = i + 1; j < words.length; j++) {
        // Compare elements of the words array
        if (collator.compare(words[i], words[j]) > 0) {
          // Swap words[i] and words[j]
          tmp = words[i];
          words[i] = words[j];
          words[j] = tmp;
        }
      }
    }
  }

  public static void printStrings(String[] words) {
    for (int i = 0; i < words.length; i++) {
      System.out.println(words[i]);
    }
  }

  static public void main(String[] args) {

    String englishRules = ("< a,A < b,B < c,C < d,D < e,E < f,F "
        + "< g,G < h,H < i,I < j,J < k,K < l,L "
        + "< m,M < n,N < o,O < p,P < q,Q < r,R "
        + "< s,S < t,T < u,U < v,V < w,W < x,X " + "< y,Y < z,Z");

    String smallnTilde = new String("\u00F1");
    String capitalNTilde = new String("\u00D1");

    String traditionalSpanishRules = ("< a,A < b,B < c,C "
        + "< ch, cH, Ch, CH " + "< d,D < e,E < f,F "
        + "< g,G < h,H < i,I < j,J < k,K < l,L " + "< ll, lL, Ll, LL "
        + "< m,M < n,N " + "< " + smallnTilde + "," + capitalNTilde + " "
        + "< o,O < p,P < q,Q < r,R " + "< s,S < t,T < u,U < v,V < w,W < x,X " + "< y,Y < z,Z");

    String[] words = { "luz", "curioso", "llama", "chalina" };

    try {
      RuleBasedCollator enCollator = new RuleBasedCollator(englishRules);
      RuleBasedCollator spCollator = new RuleBasedCollator(
          traditionalSpanishRules);

      sortStrings(enCollator, words);
      printStrings(words);

      System.out.println();

      sortStrings(spCollator, words);
      printStrings(words);
    } catch (ParseException pe) {
      System.out.println("Parse exception for rules");
    }
  }
}








13.18.Collator
13.18.1.Use RuleBasedCollator
13.18.2.Collator based compare
13.18.3.CollationKey and Collator.getInstance
13.18.4.Comparing Strings in a Locale-Independent Way
13.18.5.International friendly string comparison with case-order