如果我是你,我会分析一切只是一个时间,然后用它做任何你想要的。
这段代码就是这样做的,包括Integers
的解析(我怀疑你需要这些作为值,而不是Strings
):
public void read() throws IOException {
InputStream is = getAssets().open("USCOUNTIES.txt");
InputStreamReader iz=new InputStreamReader(is);
BufferedReader bis = new BufferedReader(iz);
String line = "";
String firstNumber = "";
String secondNumber = "";
String countyName = "";
StringTokenizer st = null;
HashMap<Pair, String> map = new HashMap<>();
while((line = bis.readLine()) != null) {
st = new StringTokenizer(line, ",");
firstNumber = (String) st.nextElement();
st = new StringTokenizer((String)st.nextElement(), ">");
secondNumber = (String) st.nextElement();
countyName = ((String) st.nextElement());
countyName = countyName.substring(0, countyName.length()-1);
int num1 = Integer.parseInt(firstNumber);
int num2 = Integer.parseInt(secondNumber);
map.put(new Pair(num1, num2), countyName);
}
}
class Pair {
int num1, num2;
Pair(int num1, int num2) {
this.num1 = num1;
this.num2 = num2;
}
public boolean equals(Object other) {
if (other instanceof Pair) {
Pair np = (Pair) other;
return this.num1 == np.num1 && this.num2 == np.num2;
}
return false;
}
public int hashCode() {
return (Integer.valueOf(num1).hashCode() >> 13)^Integer.valueOf(num2).hashCode();
};
}
现在,你可以简单地检索每个countyName
这一行:
String s = map.get(new Pair(1,69));
并返回Aleutians East
我希望得到你开始。
EDIT
这段代码使用2D SparseArray
(很像HashMap<Integer, Object>
)。有了这个,所有东西都按第一个数字排序。
public class Reader {
private String firstNumber = "";
private String secondNumber = "";
private String countyName = "";
private StringTokenizer stringTokenizer = null;
private SparseArray<SparseArray<String>> sparseArray = new SparseArray<SparseArray<String>>();
private SparseArray<String> temporarySparseArray = null;
public void readFromIS() throws IOException {
InputStream is = getAssets().open("USCOUNTIES.txt");
InputStreamReader iz=new InputStreamReader(is);
BufferedReader bis = new BufferedReader(iz);
String line = null;
while((line = bis.readLine()) != null) {
readLine(line);
}
}
public void readFromList() {
String[] strings = {
"0,1>Autauga;",
"0,2>Baldwin;",
"0,3>Barbour;",
"1,69>Aleutians East;",
"1,68>Aleutians West;"
};
for (String line : strings) {
readLine(line);
}
}
private void readLine(String line) {
stringTokenizer = new StringTokenizer(line, ",");
firstNumber = (String) stringTokenizer.nextElement();
stringTokenizer = new StringTokenizer((String)stringTokenizer.nextElement(), ">");
secondNumber = (String) stringTokenizer.nextElement();
countyName = ((String) stringTokenizer.nextElement());
countyName = countyName.substring(0, countyName.length()-1);
int num1 = Integer.parseInt(firstNumber);
int num2 = Integer.parseInt(secondNumber);
if (sparseArray.get(num1) == null) {
sparseArray.put(num1, new SparseArray<String>());
}
temporarySparseArray = sparseArray.get(num1);
temporarySparseArray.put(num2, countyName);
sparseArray.put(num1, temporarySparseArray);
temporarySparseArray = null;
}
public void test() {
readFromList();
String s = sparseArray.get(0).get(2);
SparseArray sa = sparseArray.get(0);
System.out.println(sa.size()); //should be 3
System.out.println(s); // should be Baldwin
}
}
并检索与num1
开始所有的县,说,0,你只需要使用:
SparseArray<String> startingWithZero = sparseArray.get(0);
FYI:一个SparseArray
是integers
一个HashMap
,所以不是一切都要autoboxed(从Integer
到int
,因为您不能将原始类型放入HashMap
)。
EDIT2您打印1D sparseArray的地址。
public void printEverythingStartingWithZero() {
SparseArray<String> subSparseArray = sparseArray.get(0); //You first need a 1D sparseArray
int key = 0;
for(int i = 0; i < subSparseArray.size(); i++) {
key = subSparseArray.keyAt(i);
String county = subSparseArray.get(key); //county is the String in place (0,key)
System.out.println(county);
}
}
您需要首先检索1D sparseArray
,并且前导零。
老实说,8秒钟读取3200个文件,每行3200行是相当不错的。 – 2013-03-16 21:04:55
它是一个单一的3200内衬文件。它迭代3200次。你可能有什么建议?我这样做是为了将一些文件的数据放在列表中。 – 2013-03-16 21:08:21
为什么你重新阅读相同的文件** 3200次**? – CommonsWare 2013-03-16 21:08:56