[英]null pointer exception when reading textfile
我正在嘗試閱讀一個文本文件,其中包含英語單詞及其含義的另一種語言[sinhala]用相同的標記分隔並用“|”分隔 標記。 看起來像:
abmodality=අපමාතිය
abnegate=අයිතිවාසිකම අත්හරිනවා | ත්යජනය කරනවා | පිළිගැනීම අත්හරිනවා | මතය අත්හරිනවා
abnormal=අනියම් | අපසාමාන්ය | අප්රමත | අවප්රමාණ | අස්වාභාවික | අසාමාන්ය | පුදුම
abnormalism=අසාමාන්යභාවය
abnormality=අනියම් බව | අප්රමතිය | අසාමාන්යත්වය | අසාමාන්යය | විපරීතය | විශේෂය
abnormally=අනියම් ලෙසින් | අසාමාන්ය ලෙස | රියකට ගොඩ වී | විපරීතව
aboard=දුම්රියේ | නැවේ | යාත්රාවකට ගොඩ වී | යාත්රාවේ | වාහනයක
實際上這是字典文件,它包含說明a到z的所有英文單詞。我將使用此文件創建MySQL數據庫,因為我無法通過手動插入所有單詞和含義,因為它太大了。
所以我創建了java程序,以編程方式創建MySQL查詢,所以我可以輕松插入到我的1到多數據庫,其中有2個表。實際上我的問題是程序給我一個錯誤,我發現哪一行文本文件在read.important時給出了這個錯誤令人困惑的事實是它不是一個獨特的線,如果我在閱讀不同的行時運行我的程序5次錯誤。
這是我的代碼
String[] parts ;
String en;
String[] sin;
try {
BufferedReader br = new BufferedReader(new InputStreamReader(new FileInputStream("C:\\Users\\Madhawa.se\\Desktop\\bac\\gui\\lktips-v3-lionlk.com\\a.txt"), "UTF-8"));
StringBuilder sb = new StringBuilder();
String line = br.readLine();
while (line != null) {
String s = br.readLine();
parts = s.split("=");
en=parts[0];
sin=parts[1].split(" | ");
sb.append("INSERT INTO `singlish`.`eng` (`eid`, `eword`) VALUES ('"+stpoint+"', '"+en+"');")
sb.append(System.lineSeparator());
System.out.println(en);
for(int i=0;i<sin.length;i++){
sb.append("INSERT INTO `singlish`.`sng` (`eid`, `sword`) VALUES ('"+stpoint+"', '"+sin[i]+"');");
sb.append(System.lineSeparator());
}
System.out.println(""+stpoint);
stpoint++;
}
System.out.println("finished"+subs.size());
String everything = sb.toString();
jTextArea1.append(everything);
br.close();
} catch (Exception ex) {
ex.printStackTrace();
}
但這是我得到的輸出和錯誤,但每次運行時結果都會改變
attention
3742
attentive
3743
attentively
3744
java.lang.NullPointerException
at subtitleseeker.NewJFrame.jButton3ActionPerformed(NewJFrame.java:180)
at subtitleseeker.NewJFrame.access$200(NewJFrame.java:17)
at subtitleseeker.NewJFrame$3.actionPerformed(NewJFrame.java:60)
at javax.swing.AbstractButton.fireActionPerformed(AbstractButton.java:2022)
at javax.swing.AbstractButton$Handler.actionPerformed(AbstractButton.java:2346)
at javax.swing.DefaultButtonModel.fireActionPerformed(DefaultButtonModel.java:402)
attentiveness
3745
at javax.swing.DefaultButtonModel.setPressed(DefaultButtonModel.java:259)
attenuant
在原始代碼中,您從文件中讀取一行並將其分配給line
變量。 您還檢查以確保在while循環的條件中行變量不為null。 但是,您永遠不會更新line
變量的值,而只是在循環內部的s
變量中讀取新行,從不檢查s
是否為null。
這是您的原始代碼:
StringBuilder sb = new StringBuilder();
String line = br.readLine();
while (line != null) {
String s = br.readLine();
parts = s.split("=");
en=parts[0];
sin=parts[1].split(" | ");
sb.append("INSERT INTO `singlish`.`eng` (`eid`, `eword`) VALUES ('"+stpoint+"', '"+en+"');")
sb.append(System.lineSeparator());
System.out.println(en);
for(int i=0;i<sin.length;i++) {
sb.append("INSERT INTO `singlish`.`sng` (`eid`, `sword`) VALUES ('"+stpoint+"', '"+sin[i]+"');");
sb.append(System.lineSeparator());
}
System.out.println(""+stpoint);
stpoint++;
}
這三行:
String line = br.readLine();
while (line != null) {
String s = br.readLine();
可以用這一行代替:
for (String s; (s = br.readLine()) != null; ) {
所以你的代碼是:
StringBuilder sb = new StringBuilder();
for (String s; (s = br.readLine()) != null; ) {
parts = s.split("=");
en=parts[0];
sin=parts[1].split(" | ");
sb.append("INSERT INTO `singlish`.`eng` (`eid`, `eword`) VALUES ('"+stpoint+"', '"+en+"');")
sb.append(System.lineSeparator());
System.out.println(en);
for(int i=0;i<sin.length;i++) {
sb.append("INSERT INTO `singlish`.`sng` (`eid`, `sword`) VALUES ('"+stpoint+"', '"+sin[i]+"');");
sb.append(System.lineSeparator());
}
System.out.println(""+stpoint);
stpoint++;
}
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.