簡體   English   中英

讀取文本文件時出現空指針異常

[英]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.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM