java實現讀取文件內容(不同類型)


在一些項目中大量的數據經常需要從文件中讀取,例如xml文件,txt文件,csv文件

1.讀取本地的xml文件,需要注意對應的路徑

//讀取xml文件,xmlFile為讀取文件的路徑
DocumentBuilderFactory factory = DocumentBuilderFactory.newInstance();
DocumentBuilder builder = factory.newDocumentBuilder();
Document document = builder.parse(xmlFile);

NodeList nodeList = document.getElementsByTagName(thisTag);//指定標簽(thisTag)的節點集合
for(itn i =0;i<nodeList.getLength();i++){
      // 循環獲取每個節點信息
     Node node = nodeList.item(i); 
     NamedNodeMap attributes = node.getAttributes();
     for (int j = 0; j < attributes.getLength(); j++) {
              Node attribute = attributes.item(j);          
                  System.out.println(attribute.getNodeName() + ":"
                          + attribute.getNodeValue());
              
       }


}

注意:getElementsByTagName()方法只是屬於document 與Element 的方法

所以,當針對某個Node 查找對應的節點時,需要先強制轉換為Element

Element nodeToElement =(Element) node;
NodeList osNodeList = nodeToElement.getElementsByTagName(thisTag);//thisTag為指定標簽

 

2.讀取txt文件

一般的數據存儲都是鍵值對的方式在文件中記錄,開發人員多是根據已知的鍵,從文件中取得對應的值。

例如Config.txt 中內容為:

name=jack

sex=boy

要從java程序中讀取該文件的內容

File config_file = new File("./Config") ; //此處使用相對路徑
String config_file_fullpath = config_file.getAbsoluteFile().toString() ;
readConfig config = new readConfig (config_file_fullpath) ;
String name = config.get("name");//name為jack
//對獲取的數據進行處理
//...

 

3.讀取.csv文件

csv文件一般為表格,是多行多列的數據,列對應相應不同的屬性,java實現逐行讀取每列單元格的值。

需要用到jar包(javacsv.jar)

CsvReader csv_reader = null;
char delimiter = ',';
try {
      csv_reader = new CsvReader(paramInfoFile, delimiter);//paramInfoFile為讀取的csv文件路徑
      csv_reader.setEscapeMode(CsvReader.ESCAPE_MODE_DOUBLED);
      csv_reader.readHeaders();
      } catch (Exception e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
      }
         try {
                    while (csv_reader.readRecord()) {
                        String str = csv_reader.get(0);
                        if(str.startsWith("#")){
                            continue;
                        }
                        String paramType = csv_reader.get(0);//該行的第一列數據
                        String class1 = csv_reader.get(1);//該行的第二列數據,以此類推
                        String variable = csv_reader.get(2);
                    }
                } catch (IOException e) {
                    // TODO Auto-generated catch block
                    e.printStackTrace();
                }

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM