1. 程式人生 > >java將word轉換為html

java將word轉換為html

public static void main(String[] args) throws Exception {
		String filePath = "C:/Users/Administrator/Desktop/92個診療方案及臨床路徑/";
		File file = new File(filePath);
		File[] files = file.listFiles();
		String name = null;
		for (File file2 : files) {
			Thread.sleep(500);
			name = file2.getName().substring(0, file2.getName().lastIndexOf("."));
			System.out.println(file2.getName());
			if (file2.getName().endsWith(".docx") || file2.getName().endsWith(".DOCX")) {
				CaseHtm.docx(filePath ,file2.getName(),name +".htm");
			}else{
				CaseHtm.dox(filePath ,file2.getName(),name +".htm");
			}
			
        }
	}
	/**
	 * 轉換docx
	 * @param filePath
	 * @param fileName
	 * @param htmlName
	 * @throws Exception
	 */
	public static void docx(String filePath ,String fileName,String htmlName) throws Exception{
		final String file = filePath + fileName;
		File f = new File(file);  
		// ) 載入word文件生成 XWPFDocument物件
		InputStream in = new FileInputStream(f);
		XWPFDocument document = new XWPFDocument(in);
		// ) 解析 XHTML配置 (這裡設定IURIResolver來設定圖片存放的目錄)
		File imageFolderFile = new File(filePath);
		XHTMLOptions options = XHTMLOptions.create().URIResolver(new FileURIResolver(imageFolderFile));
		options.setExtractor(new FileImageExtractor(imageFolderFile));
		options.setIgnoreStylesIfUnused(false);
		options.setFragment(true);
		// ) 將 XWPFDocument轉換成XHTML
		OutputStream out = new FileOutputStream(new File(filePath + htmlName));
		XHTMLConverter.getInstance().convert(document, out, options);
	}
	/**
	 * 轉換doc
	 * @param filePath
	 * @param fileName
	 * @param htmlName
	 * @throws Exception
	 */
	public static void dox(String filePath ,String fileName,String htmlName) throws Exception{
        final String file = filePath + fileName;
        InputStream input = new FileInputStream(new File(file));
        HWPFDocument wordDocument = new HWPFDocument(input);
        WordToHtmlConverter wordToHtmlConverter = new WordToHtmlConverter(DocumentBuilderFactory.newInstance().newDocumentBuilder().newDocument());
       //解析word文件
       wordToHtmlConverter.processDocument(wordDocument);
       Document htmlDocument = wordToHtmlConverter.getDocument();
       
       File htmlFile = new File(filePath + htmlName);
       OutputStream outStream = new FileOutputStream(htmlFile);

       DOMSource domSource = new DOMSource(htmlDocument);
       StreamResult streamResult = new StreamResult(outStream);

       TransformerFactory factory = TransformerFactory.newInstance();
       Transformer serializer = factory.newTransformer();
       serializer.setOutputProperty(OutputKeys.ENCODING, "utf-8");
       serializer.setOutputProperty(OutputKeys.INDENT, "yes");
       serializer.setOutputProperty(OutputKeys.METHOD, "html");
       
       serializer.transform(domSource, streamResult);
       outStream.close();
   }
<dependency>
    <groupId>fr.opensagres.xdocreport</groupId>
    <artifactId>fr.opensagres.xdocreport.document</artifactId>
    <version>1.0.5</version>
</dependency>
<dependency>  
    <groupId>fr.opensagres.xdocreport</groupId>  
    <artifactId>org.apache.poi.xwpf.converter.xhtml</artifactId>  
    <version>1.0.5</version>  
</dependency>
    <dependency>
    <groupId>org.apache.poi</groupId>
    <artifactId>poi</artifactId>
    <version>3.12</version>
</dependency>
<dependency>
    <groupId>org.apache.poi</groupId>
    <artifactId>poi-scratchpad</artifactId>
    <version>3.12</version>
</dependency>