解析駕考json數據,將其寫入word文件中

一、獲取駕考API

1.打開百度APK商店網站http://apistore.baidu.com/,然後搜索駕考考試,搜索到後申請apikey。


二、解析json數據

1.在eclipse上新建java工程,然後在http://download.csdn.net/detail/suningning/9513063中下載json庫,下載完畢後將其添加到java工程中

2. 通過如下代碼去獲取json數據,解析後的json數據保存在字符串jsonResult 中,然後我們通過JSONObject.fromObject()方法將其轉爲JSONObject對象。

		String httpUrl = "http://apis.baidu.com/bbtapi/jztk/jztk_query";
		String httpArg = "subject=1&model=c1&testType=order";
		String jsonResult = request(httpUrl, httpArg);
		JSONObject a = JSONObject.fromObject(jsonResult);

其中request()函數的代碼如下

	public static String request(String httpUrl, String httpArg) {
	    BufferedReader reader = null;
	    String result = null;
	    StringBuffer sbf = new StringBuffer();
	    httpUrl = httpUrl + "?" + httpArg;

	    try {
	        URL url = new URL(httpUrl);
	        HttpURLConnection connection = (HttpURLConnection) url
	                .openConnection();
	        connection.setRequestMethod("GET");
	        // 填入apikey到HTTP header
	        connection.setRequestProperty("apikey",  "自己申請的apikey");
	        connection.connect();
	        InputStream is = connection.getInputStream();
	        reader = new BufferedReader(new InputStreamReader(is, "UTF-8"));
	        String strRead = null;
	        while ((strRead = reader.readLine()) != null) {
	            sbf.append(strRead);
	            sbf.append("\r\n");
	        }
	        reader.close();
	        result = sbf.toString();
	    } catch (Exception e) {
	        e.printStackTrace();
	    }
	    return result;
	}
然後通過JSONArray b = a.getJSONArray("result");提取json數據中的題庫。

接着通過如下代碼將數據寫入文件

		for(int i=0;i<b.size();i++)
		{
			JSONObject temp=b.getJSONObject(i);
			System.out.println(temp.getString("question"));
			if((!temp.getString("url").equals(""))&&(!temp.getString("item3").equals("")))
				test.writeFile(du,temp,j++);
		}

三、關於將數據寫入word文檔

1.在java中將數據寫入word文件可以選擇jacob(java com bridge,java com橋)進行。下載地址爲http://download.csdn.net/detail/suningning/9513087

2.下載完jacob後,將其進行解壓縮,將jacob-1.18-x64.dll或者jacob-1.18-x86.dll文件放到系統的system32目錄下。將jacob.jar添加到java工程中。

3.下面是便於操作jacob而寫的一個工具類

package su;

import org.apache.commons.lang.StringUtils;
import com.jacob.activeX.ActiveXComponent;
import com.jacob.com.ComThread;
import com.jacob.com.Dispatch;
import com.jacob.com.Variant;
/**
 * 需要用jacob-1.15-M3-x86.dll放windows/system/32下面 以及jacob.jar
 */
public class docUtil{
    // word文檔
    private Dispatch doc;
//    private Dispatch doc2;
//    private Dispatch doc3;
//    private Dispatch doc4;
    // word運行程序對象
    private ActiveXComponent word;
    // 所有word文檔集合
    private Dispatch documents;
    // 選定的範圍或插入點
    private Dispatch selection;
    private boolean saveOnExit = true;
    ////////////////////////////////////////////
    public void init()
    {
    	ComThread.InitSTA();
    	word= new ActiveXComponent("Word.Application");
    	word.setProperty("Visible", new Variant(false));
    	documents = word.getProperty("Documents").toDispatch(); 
    	doc = Dispatch.call(documents, "Open",new Variant("D:\\hello4.docx")).toDispatch();
//    	doc2 = Dispatch.call(documents, "Open",new Variant("D:\\hello2.docx")).toDispatch();
//    	doc3 = Dispatch.call(documents, "Open",new Variant("D:\\hello3.docx")).toDispatch();
//    	doc4 = Dispatch.call(documents, "Open",new Variant("D:\\hello4.docx")).toDispatch();
    	selection = Dispatch.get(word, "Selection").toDispatch();
    	
    }
    public void onexit()
    {
    	Dispatch.call(doc, "Save");
    	word.invoke("Quit", new Variant[] {});
    	ComThread.Release();
    }
    public docUtil() {
//        if (word == null) {
//        word = new ActiveXComponent("Word.Application");
//        word.setProperty("Visible", new Variant(false));
//    }
//    if (documents == null)
//        documents = word.getProperty("Documents").toDispatch();
    }
    public void moveHead(){
    	selection = Dispatch.get(word, "Selection").toDispatch();
    }
    /**
     * 設置退出時參數
     *
     * @param saveOnExit
     * boolean true-退出時保存文件,false-退出時不保存文件
     */
    public void setSaveOnExit(boolean saveOnExit) {
        this.saveOnExit = saveOnExit;
    }
    /**
     * 創建一個新的word文檔
     */
    public void createNewDocument() {
        doc = Dispatch.call(documents, "Add").toDispatch();
        selection = Dispatch.get(word, "Selection").toDispatch();
    }
    /**
     * 打開一個已存在的文檔
     * @param docPath
     */
    public void openDocument(String docPath) {
        closeDocument();
        doc = Dispatch.call(documents, "Open", docPath).toDispatch();
        selection = Dispatch.get(word, "Selection").toDispatch();
     }
    /**
     * 把選定的內容或插入點向上移動
     * @param pos  移動的距離
     */
    public void moveUp(int pos) {
        if (selection == null)
        selection = Dispatch.get(word, "Selection").toDispatch();
        for (int i = 0; i < pos; i++)
        Dispatch.call(selection, "MoveUp");
    }
    /**
     * 把選定的內容或者插入點向下移動
     * @param pos  移動的距離
     */
    public void moveDown(int pos) {
        if (selection == null)
        selection = Dispatch.get(word, "Selection").toDispatch();
        for (int i = 0; i < pos; i++)
        Dispatch.call(selection, "MoveDown");
    }
    /**
     * 把選定的內容或者插入點向左移動
     * @param pos  移動的距離
     */
    public void moveLeft(int pos) {
        if (selection == null)
        selection = Dispatch.get(word, "Selection").toDispatch();
        for (int i = 0; i < pos; i++) {
            Dispatch.call(selection, "MoveLeft");
        }
    }

    /**
     * 把選定的內容或者插入點向右移動
     * @param pos 移動的距離
     */
    public void moveRight(int pos) {
     if (selection == null)
      selection = Dispatch.get(word, "Selection").toDispatch();
     for (int i = 0; i < pos; i++)
      Dispatch.call(selection, "MoveRight");
    }

   /**
    * 把插入點移動到文件首位置
    */
    public void moveStart() {
     if (selection == null)
      selection = Dispatch.get(word, "Selection").toDispatch();
      Dispatch.call(selection, "HomeKey", new Variant(6));
    }

    /**
     * 從選定內容或插入點開始查找文本
     *
     * @param toFindText 要查找的文本
     * @return boolean true-查找到並選中該文本,false-未查找到文本
     */
    public boolean find(String toFindText) {
        if (toFindText == null || toFindText.equals(""))
         return false;
        // 從selection所在位置開始查詢
        Dispatch find = word.call(selection, "Find").toDispatch();
        // 設置要查找的內容
        Dispatch.put(find, "Text", toFindText);
        // 向前查找
        Dispatch.put(find, "Forward", "True");
        // 設置格式
        Dispatch.put(find, "Format", "True");
        // 大小寫匹配
        Dispatch.put(find, "MatchCase", "True");
        // 全字匹配
        Dispatch.put(find, "MatchWholeWord", "True");
        // 查找並選中
        return Dispatch.call(find, "Execute").getBoolean();
    }

    /**
     * 把選定選定內容設定爲替換文本
     * @param toFindText 查找字符串
     * @param newText 要替換的內容
     * @return
     */
    public boolean replaceText(String toFindText, String newText) {
        if (!find(toFindText))
         return false;
        Dispatch.put(selection, "Text", newText);
        return true;
    }
   
    /**
     * 全局替換文本
     * @param toFindText 查找字符串
     * @param newText 要替換的內容
     */
    public void replaceAllText(String toFindText, String newText) {
        while (find(toFindText)) {
            Dispatch.put(selection, "Text", newText);
            Dispatch.call(selection, "MoveRight");
        }
    }
    
    public void replaceTextOne(String toFindText, String newText) {
        if (find(toFindText)) {
            Dispatch.put(selection, "Text", newText);
            Dispatch.call(selection, "MoveRight");
        }
    }
    

    /**
     * 在當前插入點插入字符串
     * @param newText 要插入的新字符串
     */
    public void insertkong()
    {
    	Dispatch.call(selection, "TypeParagraph");// 插入一個空行 
    }
    public void insertText(String newText) {
 //       Dispatch.put(selection, "Text", newText);
        
    	selection=Dispatch.get(word,"Selection").toDispatch();
    	Dispatch.call(selection, "MoveRight", new Variant(1), new Variant(1)); 
    	Dispatch.put(selection,"Text",newText);
    	Dispatch.call(selection, "MoveRight", new Variant(1), new Variant(1));  
//    	Dispatch.call(selection, "TypeParagraph");// 插入一個空行 
        
        
    }
    public void insertText2(String num) {
        Dispatch.put(selection, "Text", num);
        
//    	selection=Dispatch.get(word,"Selection").toDispatch();
//    	Dispatch.call(selection, "MoveRight", new Variant(1), new Variant(1)); 
//    	Dispatch.put(selection,"Text",newText);
//    	Dispatch.call(selection, "MoveRight", new Variant(1), new Variant(1));  
//    	Dispatch.call(selection, "TypeParagraph");// 插入一個空行       
        
    }
    
//    public void insertparag(String text)
//    {
//    	
//    	Dispatch wordcontent=Dispatch.get(documents,"Content").toDispatch();
//    	Dispatch.call(wordcontent, "InsertAfter", text);
////    	Dispatch paragraphs = Dispatch.get(content, "Paragraphs").toDispatch();
////    	int paragraphCount = Dispatch.get(paragraphs, "Count").changeType(Variant.VariantInt).getInt();// 一共的段落數
//    	selection = Dispatch.get(word, "Selection").toDispatch();
//    	Dispatch.call(selection, "TypeParagraph");// 插入一個空行 
//    	
//    	
//    }
    /**
     *
     * @param toFindText 要查找的字符串
     * @param imagePath 圖片路徑
     * @return
     */
    public boolean replaceImage(String toFindText, String imagePath) {
        if (!find(toFindText))
         return false;
        Dispatch.call(Dispatch.get(selection, "InLineShapes").toDispatch(),
          "AddPicture", imagePath);
        return true;
    }

    /**
     * 全局替換圖片
     * @param toFindText 查找字符串
     * @param imagePath 圖片路徑
     */
    public void replaceAllImage(String toFindText, String imagePath) {
        while (find(toFindText)) {
         Dispatch.call(Dispatch.get(selection, "InLineShapes").toDispatch(),
           "AddPicture", imagePath);
         Dispatch.call(selection, "MoveRight");
        }
    }

    /**
     * 在當前插入點插入圖片
     * @param imagePath 圖片路徑
     */
     public void insertImage(String imagePath) {
//         Dispatch.call(Dispatch.get(selection, "InLineShapes").toDispatch(),
//        		 	   "AddPicture", imagePath);
    	 
 		selection = Dispatch.get(word, "Selection").toDispatch();
 		Dispatch inLineShapes = Dispatch.get(selection, "InLineShapes").toDispatch(); 
 		Dispatch picture = Dispatch.call(inLineShapes, "AddPicture", imagePath).toDispatch();
 		Dispatch.call(selection, "MoveRight", new Variant(1), new Variant(1)); 
     }

    /**
     * 合併單元格
     * @param tableIndex
     * @param fstCellRowIdx
     * @param fstCellColIdx
     * @param secCellRowIdx
     * @param secCellColIdx
     */
    public void mergeCell(int tableIndex, int fstCellRowIdx, int fstCellColIdx,
        int secCellRowIdx, int secCellColIdx) {
        // 所有表格
        Dispatch tables = Dispatch.get(doc, "Tables").toDispatch();
        // 要填充的表格
        Dispatch table = Dispatch.call(tables, "Item",
        				   new Variant(tableIndex)).toDispatch();
        Dispatch fstCell = Dispatch.call(table, "Cell",
				           new Variant(fstCellRowIdx), 
				           new Variant(fstCellColIdx)).toDispatch();
        Dispatch secCell = Dispatch.call(table, "Cell",
				           new Variant(secCellRowIdx), 
				           new Variant(secCellColIdx)).toDispatch();
        Dispatch.call(fstCell, "Merge", secCell);
    }

    /**
     * 在指定的單元格里填寫數據
     *
     * @param tableIndex
     * @param cellRowIdx
     * @param cellColIdx
     * @param txt
     */
    public void putTxtToCell(int tableIndex, int cellRowIdx, int cellColIdx,
        String txt) {
        // 所有表格
        Dispatch tables = Dispatch.get(doc, "Tables").toDispatch();
        // 要填充的表格
        Dispatch table = Dispatch.call(tables, "Item", 
        			new Variant(tableIndex)).toDispatch();
        Dispatch cell = Dispatch.call(table, "Cell", 
	        		new Variant(cellRowIdx),
	        		new Variant(cellColIdx)).toDispatch();
        Dispatch.call(cell, "Select");
        Dispatch.put(selection, "Text", txt);
    }
    /**
     * 得到指定單元格的值
     *
     * @param tableIndex
     * @param cellRowIdx
     * @param cellColIdx
     */
    public String getTxtFromCell(int tableIndex, int cellRowIdx, int cellColIdx) {
        // 所有表格
        Dispatch tables = Dispatch.get(doc, "Tables").toDispatch();
        // 要填充的表格
        Dispatch table = Dispatch.call(tables, "Item", 
        			new Variant(tableIndex)).toDispatch();
        Dispatch cell = Dispatch.call(table, "Cell", 
	        		new Variant(cellRowIdx),
	        		new Variant(cellColIdx)).toDispatch();
        Dispatch.call(cell, "Select");
        return StringUtils.trim(Dispatch.get(selection, "Text").toString());
    }
    /**
     * 在當前文檔拷貝剪貼板數據
     * @param pos
     */
    public void pasteExcelSheet(String pos){
        moveStart();
        if (this.find(pos)) {
            Dispatch textRange = Dispatch.get(selection, "Range").toDispatch();
            Dispatch.call(textRange, "Paste");
        }
    }

    /**
     * 在當前文檔指定的位置拷貝表格
     * @param pos 當前文檔指定的位置
     * @param tableIndex 被拷貝的表格在word文檔中所處的位置
     */
    public void copyTable(String pos, int tableIndex) {
        // 所有表格
        Dispatch tables = Dispatch.get(doc, "Tables").toDispatch();
        // 要填充的表格
        Dispatch table = Dispatch.call(tables, "Item", 
        				new Variant(tableIndex)).toDispatch();
        Dispatch range = Dispatch.get(table, "Range").toDispatch();
        Dispatch.call(range, "Copy");
        if (this.find(pos)) {
            Dispatch textRange = Dispatch.get(selection, "Range").toDispatch();
            Dispatch.call(textRange, "Paste");
        }
    }

    /**
     * 在當前文檔指定的位置拷貝來自另一個文檔中的表格
     * @param anotherDocPath 另一個文檔的磁盤路徑
     * @param tableIndex 被拷貝的表格在另一格文檔中的位置
     * @param pos  當前文檔指定的位置
     */
    public void copyTableFromAnotherDoc(String anotherDocPath, int tableIndex,String pos) {
        Dispatch doc2 = null;
        try {
            doc2 = Dispatch.call(documents, "Open", anotherDocPath).toDispatch();
            // 所有表格
            Dispatch tables = Dispatch.get(doc2, "Tables").toDispatch();
            // 要填充的表格
            Dispatch table = Dispatch.call(tables, "Item",
            				new Variant(tableIndex)).toDispatch();
            Dispatch range = Dispatch.get(table, "Range").toDispatch();
            Dispatch.call(range, "Copy");
            if (this.find(pos)) {
                Dispatch textRange = Dispatch.get(selection, "Range").toDispatch();
                Dispatch.call(textRange, "Paste");
            }
        } catch (Exception e) {
            e.printStackTrace();
        } finally {
            if (doc2 != null) {
                Dispatch.call(doc2, "Close", new Variant(saveOnExit));
                doc2 = null;
         }
        }
    }
    /**
     * 在當前文檔指定的位置拷貝來自另一個文檔中的圖片
     * @param anotherDocPath 另一個文檔的磁盤路徑
     * @param shapeIndex 被拷貝的圖片在另一格文檔中的位置
     * @param pos 當前文檔指定的位置
     */
     public void copyImageFromAnotherDoc(String anotherDocPath,int shapeIndex,String pos){
         Dispatch doc2 = null;
         try {
             doc2 = Dispatch.call(documents, "Open", anotherDocPath).toDispatch();
             Dispatch shapes = Dispatch.get(doc2, "InLineShapes").toDispatch();
             Dispatch shape = Dispatch.call(shapes, "Item", 
            		 		  new Variant(shapeIndex)).toDispatch();
             Dispatch imageRange = Dispatch.get(shape, "Range").toDispatch();
             Dispatch.call(imageRange, "Copy");
             if (this.find(pos)) {
                 Dispatch textRange = Dispatch.get(selection, "Range").toDispatch();
                 Dispatch.call(textRange, "Paste");
             }
         } catch (Exception e) {
             e.printStackTrace();
         } finally {
             if (doc2 != null) {
                 Dispatch.call(doc2, "Close", new Variant(saveOnExit));
                 doc2 = null;
             }
         }
     }
    /**
     * 創建表格
     * @param pos 位置
     * @param cols 列數
     * @param rows 行數
     */
    public void createTable(String pos, int numCols, int numRows) {
        if (find(pos)) {
            Dispatch tables = Dispatch.get(doc, "Tables").toDispatch();
            Dispatch range = Dispatch.get(selection, "Range").toDispatch();
            Dispatch newTable = Dispatch.call(tables, "Add", range,
              new Variant(numRows), new Variant(numCols)).toDispatch();
            Dispatch.call(selection, "MoveRight");
        }else{
            Dispatch tables = Dispatch.get(doc, "Tables").toDispatch();
            Dispatch range = Dispatch.get(selection, "Range").toDispatch();
            Dispatch newTable = Dispatch.call(tables, "Add", range,
              new Variant(numRows), new Variant(numCols)).toDispatch();
            Dispatch.call(selection, "MoveRight");
        }
    }

    /**
     * 在指定行前面增加行
     * @param tableIndex word文件中的第N張表(從1開始)
     * @param rowIndex 指定行的序號(從1開始)
     */
    public void addTableRow(int tableIndex, int rowIndex) {
        // 所有表格
        Dispatch tables = Dispatch.get(doc, "Tables").toDispatch();
        // 要填充的表格
        Dispatch table = Dispatch.call(tables, "Item", 
        				new Variant(tableIndex)).toDispatch();
        // 表格的所有行
        Dispatch rows = Dispatch.get(table, "Rows").toDispatch();
        Dispatch row = Dispatch.call(rows, "Item", 
        				new Variant(rowIndex)).toDispatch();
        Dispatch.call(rows, "Add", new Variant(row));
    }

    /**
     * 在第1行前增加一行
     * @param tableIndex word文檔中的第N張表(從1開始)
     */
    public void addFirstTableRow(int tableIndex) {
        // 所有表格
        Dispatch tables = Dispatch.get(doc, "Tables").toDispatch();
        // 要填充的表格
        Dispatch table = Dispatch.call(tables, "Item", new Variant(tableIndex))
          .toDispatch();
        // 表格的所有行
        Dispatch rows = Dispatch.get(table, "Rows").toDispatch();
        Dispatch row = Dispatch.get(rows, "First").toDispatch();
        Dispatch.call(rows, "Add", new Variant(row));
    }

    /**
     * 在最後1行前增加一行
     * @param tableIndex word文檔中的第N張表(從1開始)
     */
    public void addLastTableRow(int tableIndex) {
        // 所有表格
        Dispatch tables = Dispatch.get(doc, "Tables").toDispatch();
        // 要填充的表格
        Dispatch table = Dispatch.call(tables, "Item", new Variant(tableIndex))
          .toDispatch();
        // 表格的所有行
        Dispatch rows = Dispatch.get(table, "Rows").toDispatch();
        Dispatch row = Dispatch.get(rows, "Last").toDispatch();
        Dispatch.call(rows, "Add", new Variant(row));
    }
    /**
     * 增加一行
     *
     * @param tableIndex word文檔中的第N張表(從1開始)
     *            
     * Dispatch range = Dispatch.get(selection, "Range").toDispatch();
     * Dispatch newTable = Dispatch.call(tables, "Add", range,
     *         			  new Variant(numRows), new Variant(numCols)).toDispatch();
     */
    public void addRow(int tableIndex) {
        Dispatch tables = Dispatch.get(doc, "Tables").toDispatch();
        // 要填充的表格
        Dispatch table = Dispatch.call(tables, "Item", 
        		new Variant(tableIndex)).toDispatch();
        // 表格的所有行
        Dispatch rows = Dispatch.get(table, "Rows").toDispatch();
        Dispatch.call(rows, "Add");
    }

    /**
     * 增加一列
     * @param tableIndex  word文檔中的第N張表(從1開始)
     */
    public void addCol(int tableIndex) {
        // 所有表格
        Dispatch tables = Dispatch.get(doc, "Tables").toDispatch();
        // 要填充的表格
        Dispatch table = Dispatch.call(tables, "Item", new Variant(tableIndex))
          .toDispatch();
        // 表格的所有行
        Dispatch cols = Dispatch.get(table, "Columns").toDispatch();
        Dispatch.call(cols, "Add").toDispatch();
        Dispatch.call(cols, "AutoFit");
    }

    /**
     * 在指定列前面增加表格的列
     *
     * @param tableIndex word文檔中的第N張表(從1開始)
     * @param colIndex 制定列的序號 (從1開始)
     */
    public void addTableCol(int tableIndex, int colIndex) {
        // 所有表格
        Dispatch tables = Dispatch.get(doc, "Tables").toDispatch();
        // 要填充的表格
        Dispatch table = Dispatch.call(tables, "Item", new Variant(tableIndex))
          .toDispatch();
        // 表格的所有行
        Dispatch cols = Dispatch.get(table, "Columns").toDispatch();
        System.out.println(Dispatch.get(cols, "Count"));
        Dispatch col = Dispatch.call(cols, "Item", new Variant(colIndex))
          .toDispatch();
        Dispatch.call(cols, "Add", col).toDispatch();
        Dispatch.call(cols, "AutoFit");
    }

    /**
     * 在第1列前增加一列
     *
     * @param tableIndex word文檔中的第N張表(從1開始)
     */
    public void addFirstTableCol(int tableIndex) {
        Dispatch tables = Dispatch.get(doc, "Tables").toDispatch();
        // 要填充的表格
        Dispatch table = Dispatch.call(tables, "Item", new Variant(tableIndex))
          .toDispatch();
        // 表格的所有行
        Dispatch cols = Dispatch.get(table, "Columns").toDispatch();
        Dispatch col = Dispatch.get(cols, "First").toDispatch();
        Dispatch.call(cols, "Add", col).toDispatch();
        Dispatch.call(cols, "AutoFit");
    }

    /**
     * 在最後一列前增加一列
     * @param tableIndex word文檔中的第N張表(從1開始)
     */
    public void addLastTableCol(int tableIndex) {
        Dispatch tables = Dispatch.get(doc, "Tables").toDispatch();
        // 要填充的表格
        Dispatch table = Dispatch.call(tables, "Item", new Variant(tableIndex))
          .toDispatch();
        // 表格的所有行
        Dispatch cols = Dispatch.get(table, "Columns").toDispatch();
        Dispatch col = Dispatch.get(cols, "Last").toDispatch();
        Dispatch.call(cols, "Add", col).toDispatch();
        Dispatch.call(cols, "AutoFit");
    }
    /**
     * 自動調整表格
     *
     */
    public void autoFitTable(){
        Dispatch tables = Dispatch.get(doc, "Tables").toDispatch();
        int count = Dispatch.get(tables, "Count").toInt();
        for(int i=0;i<count;i++){
            Dispatch table = Dispatch.call(tables, "Item", new Variant(i+1)).toDispatch();
            Dispatch cols = Dispatch.get(table, "Columns").toDispatch();
            Dispatch.call(cols, "AutoFit");
        }
    }
    /**
     * 調用word裏的宏以調整表格的寬度,其中宏保存在document下
     *
     */
    public void callWordMacro(){
        Dispatch tables = Dispatch.get(doc, "Tables").toDispatch();
        int count = Dispatch.get(tables, "Count").toInt();
        Variant vMacroName = new Variant("Normal.NewMacros.tableFit");
        Variant vParam = new Variant("param1");
        Variant para[]=new Variant[]{vMacroName};
        for(int i=0;i<count;i++){
            Dispatch table = Dispatch.call(tables, "Item", new Variant(i+1)).toDispatch();
            Dispatch.call(table, "Select");
            Dispatch.call(word,"Run","tableFitContent");
        }
    }
    /**
     * 設置當前選定內容的字體
     *
     * @param boldSize
     * @param italicSize
     * @param underLineSize 下劃線
     * @param colorSize  字體顏色
     * @param size 字體大小
     * @param name 字體名稱
     */
    public void setFont(boolean bold, boolean italic, boolean underLine,
        String colorSize, String size, String name) {
        Dispatch font = Dispatch.get(selection, "Font").toDispatch();
        Dispatch.put(font, "Name", new Variant(name));
        Dispatch.put(font, "Bold", new Variant(bold));
        Dispatch.put(font, "Italic", new Variant(italic));
        Dispatch.put(font, "Underline", new Variant(underLine));
        Dispatch.put(font, "Color", colorSize);
        Dispatch.put(font, "Size", size);
    }

    /**
     * 文件保存或另存爲
     *
     * @param savePath 保存或另存爲路徑
     */
    public void save(String savePath) {
        Dispatch.call(Dispatch.call(word, "WordBasic").getDispatch(),
       "FileSaveAs", savePath);
    }

    /**
     * 關閉文檔
     *@param val 0不保存修改 -1 保存修改 -2 提示是否保存修改
     */
    public void closeDocument(int val) {
        Dispatch.call(doc, "Close", new Variant(val));
        doc = null;
    }
    /**
     * 關閉當前word文檔
     *
     */
    public void closeDocument() {
        if (doc != null) {
            Dispatch.call(doc, "Save");
            Dispatch.call(doc, "Close", new Variant(saveOnExit));
            doc = null;
        }
    }

    /**
     * 關閉全部應用
     *
     */
    public void close() {
        if (word != null) {
            Dispatch.call(word, "Quit");
            word = null;
        }
        selection = null;
        documents = null;
    }

    /**
     * 打印當前word文檔
     *
     */
    public void printFile() {
        if (doc != null) {
            Dispatch.call(doc, "PrintOut");
        }
    }
    public static boolean replaceWordText(String docPath,String modifysavePath,String bookMark,String replaceWord){
    	 docUtil msWordManager = new docUtil();
         try {
             msWordManager.openDocument(docPath);
             msWordManager.save(modifysavePath);
             msWordManager.closeDocument(0);
         } catch (Exception e) {
             e.printStackTrace();
         }finally{
             msWordManager.close();
         }
         return true;
    }
}

4.在主函數中通過下面代碼進行初始化

docUtil du=new docUtil();
du.init();

5.通過下面代碼將解析到的json數據寫入word文件

	dutemp.insertText2(num+1+"]");
		String temp=c.getString("answer");
		String temp2=null;
		if (temp.equals("1"))
			temp2="a";
		else if(temp.equals("2"))
			temp2="b";
		else if(temp.equals("3"))
			temp2="c";
		else if(temp.equals("4"))
			temp2="d";	
		dutemp.insertText(c.getString("question"));
		String url=c.getString("url");
		if (!url.equals(""))
		   dutemp.insertImage(c.getString("url"));
		dutemp.insertText("("+temp2+")");
		dutemp.insertkong();
		dutemp.insertText2("a.");
		dutemp.insertText(c.getString("item1")+";");
		dutemp.insertkong();
		dutemp.insertText2("b.");
		dutemp.insertText(c.getString("item2")+";");
		dutemp.insertkong();
		dutemp.insertText2("c.");
		dutemp.insertText(c.getString("item3")+";");
		dutemp.insertkong();
		dutemp.insertText2("d.");
		dutemp.insertText(c.getString("item4")+";");
		dutemp.insertkong();
		dutemp.insertText2("p]");
		dutemp.insertText(c.getString("explains"));
		dutemp.insertkong();	

6.主函數調用du.onexit();保存文件

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章