我想将displayDirectoryContents的输出写入Excel工作表

我想将displayDirectoryContents的输出写入Excel工作表

我尝试使用Apache POI方法将输出输出到Excel工作表 一列中的文件夹和文件名 另一列中文件的名称 导入语句

public class Excel {

private static String dest = "C:\\Users\\mahselva\\testexcel.xls";
private static HSSFWorkbook myWorkBook = new HSSFWorkbook();
private static HSSFSheet mySheet = myWorkBook.createSheet();

public static void excelLog(String filename,String message,int rowNum) 
{

HSSFRow myRow = null;
HSSFCell myCell = null;
String excelData[][] = new String[1][2];
excelData[0][0] = filename;
excelData[0][1] = message;

myRow = mySheet.createRow(rowNum);

for (int cellNum = 0; cellNum < 2; cellNum++) {
    myCell = myRow.createCell(cellNum);
    myCell.setCellValue(excelData[0][cellNum]);

}
try {
    FileOutputStream out = new FileOutputStream(dest);
    myWorkBook.write(out);
    out.close();
} catch (Exception e) {
    e.printStackTrace();
}
}

public static void main(String[] args) {
File currentDir = new File("C:\\OracleATS\\openScript"); // current 
directory
displayDirectoryContents(currentDir);
}
public static void displayDirectoryContents(File dir) {
try {
    int i = 0;
    File[] files = dir.listFiles();
    for (File file : files) {
        if (file.isDirectory()) {
            Path path = Paths.get(file.getcanonicalPath());
            //System.out.println("Folder" 
+path.getFileName().toString());
            excelLog("Folder",path.getFileName().toString(),i);
            i++;
            displayDirectoryContents(file);
        } else {
            Path path = Paths.get(file.getcanonicalPath());
            //System.out.println(path.getFileName().toString());
            excelLog("File",i);
            i++;
        }

    }
} catch (IOException e) {
    e.printStackTrace();
} 
}
}

我想要Excel工作表中的两列,其中第1列包含File或 包含文件/文件夹名称的文件夹和列2 例如 文件books.xml 文件夹脚本

因此我想将输出写入Excel工作表 我正在使用excel日志功能写​​入输出屏幕

epavelly 回答:我想将displayDirectoryContents的输出写入Excel工作表

我用它来写一个excel-但是我将其设置为.csv格式,而不是xls。因此,这可能不是您所需要的,但是它仍然部分有用,因为它正在写入可以轻松地由excel打开的文件中。

public static void printAtFile(String filename,String header,String content[])
    {
        filename+=".csv";
        System.out.println("Start creating file "+filename);
        PrintWriter writer = null;
        try {
            writer = new PrintWriter(filename);
            writer.println(header);
            for(String u:content)
                writer.println(u);
            writer.close();
        } catch (Exception ex) {
            System.out.println("Error while writing at file "+filename);
        }
    }
本文链接:https://www.f2er.com/3160271.html

大家都在问