在一些項目中大量的數據經常需要從文件中讀取,例如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(); }