一、获取驾考API
1.打开百度APK商店网站http://apistore.baidu.com/,然后搜索驾考考试,搜索到后申请apikey。
二、解析json数据
1.在eclipse上新建java工程,然后在中下载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桥)进行。下载地址为
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();保存文件