我有这个函数将.properties文件中的值存储到树图(translatedMap)中,然后从" keyMap"中检索新值。并将它们存储到"翻译地图"同样。问题是无论我做什么,似乎总是将大写键与非大写键分开。这是我的代码:
Properties translation = new Properties(){
private static final long serialVersionUID = 1L;
@Override
public synchronized Enumeration<Object> keys() {
return Collections.enumeration(new TreeSet<Object>(super
.keySet()));
}
};
//creates file and stores values of keyMap into the file
try {
TreeMap<String, String> translatedMap = new TreeMap<String, String>(String.CASE_INSENSITIVE_ORDER);
InputStreamReader in = new InputStreamReader(new FileInputStream(filePath), "UTF-8");
translation.load(in);
// Store all values to TreeMap and sort
Enumeration<?> e = translation.propertyNames();
while (e.hasMoreElements()) {
String key = (String) e.nextElement();
if (key.matches(".#")) {
} else {
String value = translation.getProperty(key);
translatedMap.put(key, value);
}
}
// Add new values to translatedMap
for (String key : keyMap.keySet()) {
// Handle if some keys have already been added; delete so they can be re-added
if (translatedMap.containsKey(key)) {
translatedMap.remove(key);
}
translatedMap.put(key, keyMap.get(key));
}
in.close();
translation.putAll(translatedMap);
File translationFile = new File(filePath);
OutputStreamWriter out = new OutputStreamWriter(new FileOutputStream(translationFile, false), "UTF-8");
translation.store(out, null);
out.close();
} catch (IOException e) {
e.printStackTrace();
}
}
我得到的输出类似于:
CAPITALIZED_KEY1 = value1
CAPITALIZED_KEY2 = value2
alowercase.key = value3
anotherlowercase.key = value4
morelowercase.keys =值5
当我想要它出来时:
alowercase.key = value3
anotherlowercase.key = value4
CAPITALIZED_KEY1 = value1
CAPITALIZED_KEY2 = value2
morelowercase.keys =值5
答案 0 :(得分:1)
未订购属性。您插入到它们中的顺序无关紧要,或者如果您使用已排序的东西调用putAll(),它们会扩展Hashtable。请参阅here。
答案 1 :(得分:1)
基本问题是 - 虽然排序不区分大小写 - 但有序映射仍然区分大小写,因为属性名称区分大小写。
因此覆盖了属性,并且在编写时将名称排序为不区分大小写。
public class SortedProperties extends Properties {
@Override
public void store(Writer writer, String comments)
throws IOException {
List<String> names = new ArrayList<>();
for (Enumeration<?> en = propertyNames(); en.hasMoreElements(); ) {
String name = en.nextElement().toString();
names.add(name);
}
Collections.sort(names, new Comparator<String>() {
@Override
public int compareTo(String other) {
toLowerCase().compareTo(other.toLowerCase());
}
});
//... write all properties
}
答案 2 :(得分:0)
为了达到这个目的,我最终完全避免了商店功能。我在treeMap中进行了排序。我使用了缓冲的写入器并写入文件。像这样:
Properties translation = new Properties();
//creates file and stores values of keyMap into the file
try {
TreeMap<String, String> translatedMap = new TreeMap<String, String>(new Comparator<String>() {
public int compare(String o1, String o2) {
return o1.toLowerCase().compareTo(o2.toLowerCase());
}
});
InputStreamReader in = new InputStreamReader(new FileInputStream(filePath), "UTF-8");
translation.load(in);
// Store all values to TreeMap and sort
for (String key : translation.stringPropertyNames()) {
keyMap.put(key, translation.getProperty(key));
}
in.close();
Iterator<String> it = keyMap.keySet().iterator();
while (it.hasNext()) {
String key = it.next();
translatedMap.put(key, keyMap.get(key));
}
BufferedWriter bw = new BufferedWriter(new OutputStreamWriter(new FileOutputStream(filePath, false), "UTF-8"));
bw.write("#" + new Date().toString());
bw.newLine();
Iterator<String> it2 = translatedMap.keySet().iterator();
while (it2.hasNext()) {
String key = it2.next();
bw.write(key + '=' + translatedMap.get(key));
bw.newLine();
}
bw.close();
} catch (IOException e) {
e.printStackTrace();
}
}