1

xml データを csv ファイルに書き込もうとしています。データの長さが長すぎる場合を除いて、すべて正常に機能しており、新しい行にデータを書き込みます。たとえば、アドレスが長すぎる場合は、次の行に移動してからデータを書き込みます。

public class ExportToCSV {

public static final String LINE_BREAK = "\n";
List<Line> lines = new ArrayList<Line>();
public static void main(String argv[]) {

    try {   File fXmlFile = new File("C:/Users/Master/Desktop/demo_jar/Eff_SOR.xml");
        DocumentBuilderFactory dbFactory = DocumentBuilderFactory.newInstance();
        DocumentBuilder dBuilder = dbFactory.newDocumentBuilder();
        Document doc = dBuilder.parse(fXmlFile);
        doc.getDocumentElement().normalize();

        System.out.println("Root element :" + doc.getDocumentElement().getNodeName());
        NodeList nList = doc.getElementsByTagName("record");
        System.out.println("----------------------------");
        List< Map<String, String>> list = new ArrayList<Map<String,String>>();

        for (int temp = 0; temp < nList.getLength(); temp++) {
             Map<String, String> map = new HashMap<String, String>();
             Node nNode = nList.item(temp);
             if (nNode.getNodeType() == Node.ELEMENT_NODE) {
                   Element eElement = (Element) nNode; 

                   map.put("Address", eElement.getElementsByTagName("address_").item(0).getTextContent());                                 
                   map.put("Price1", eElement.getElementsByTagName("price1").item(0).getTextContent());                  
                   map.put("Base_qty1", eElement.getElementsByTagName("base_qty1").item(0).getTextContent());
                   map.put("base_price1", eElement.getElementsByTagName("base_price1").item(0).getTextContent());         

                   list.add(map);               
              }
        }

        generateCsvFile("C:\\Users\\Master\\Desktop\\demo_jar\\testCSV.csv", list );
    } catch (Exception e) {
        e.printStackTrace();
    }
}

private static void generateCsvFile(String sFilename, List< Map<String, String>>  test) {
    try {
        FileWriter writer = new FileWriter(sFilename);

        writer.append("Address");
        writer.append(",");
        writer.append("Price1");
        writer.append(",");
        writer.append("Base_qty1");
        writer.append(",");
        writer.append("Price2");
        writer.append(",");
        writer.append("base_price1");
        writer.append(",");           
        writer.append(LINE_BREAK);

        for (Map<String, String> map : test) {              

        Iterator iterator = map.entrySet().iterator();
        while (iterator.hasNext()) {
            Map.Entry<String,String> mapEntry = (Map.Entry<String,String>) iterator.next();
           //ystem.out.println("key: " + mapEntry.getKey() + ", value:" + mapEntry.getValue());

            writer.append(mapEntry.getValue());
            writer.append(",");
            iterator.remove();
        }
        writer.append(LINE_BREAK);
        }
        writer.flush();
        writer.close();
    }catch(Exception e){

    }
}
}
4

1 に答える 1

1

.csv は、フィールド値を区切るためにカンマが使用された単なるテキスト ファイルです。そのため、ファイルを Excel で最初に開いたときに表示されるセル サイズを制御する方法はありません。

于 2013-11-11T07:37:48.937 に答える