解析驾考json数据,将其写入word文件中

2024-02-17 00:38

本文主要是介绍解析驾考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 headerconnection.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();保存文件

这篇关于解析驾考json数据,将其写入word文件中的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/716176

相关文章

SpringBoot多环境配置数据读取方式

《SpringBoot多环境配置数据读取方式》SpringBoot通过环境隔离机制,支持properties/yaml/yml多格式配置,结合@Value、Environment和@Configura... 目录一、多环境配置的核心思路二、3种配置文件格式详解2.1 properties格式(传统格式)1.

解决pandas无法读取csv文件数据的问题

《解决pandas无法读取csv文件数据的问题》本文讲述作者用Pandas读取CSV文件时因参数设置不当导致数据错位,通过调整delimiter和on_bad_lines参数最终解决问题,并强调正确参... 目录一、前言二、问题复现1. 问题2. 通过 on_bad_lines=‘warn’ 跳过异常数据3

全面解析Golang 中的 Gorilla CORS 中间件正确用法

《全面解析Golang中的GorillaCORS中间件正确用法》Golang中使用gorilla/mux路由器配合rs/cors中间件库可以优雅地解决这个问题,然而,很多人刚开始使用时会遇到配... 目录如何让 golang 中的 Gorilla CORS 中间件正确工作一、基础依赖二、错误用法(很多人一开

Python进行JSON和Excel文件转换处理指南

《Python进行JSON和Excel文件转换处理指南》在数据交换与系统集成中,JSON与Excel是两种极为常见的数据格式,本文将介绍如何使用Python实现将JSON转换为格式化的Excel文件,... 目录将 jsON 导入为格式化 Excel将 Excel 导出为结构化 JSON处理嵌套 JSON:

Mysql中设计数据表的过程解析

《Mysql中设计数据表的过程解析》数据库约束通过NOTNULL、UNIQUE、DEFAULT、主键和外键等规则保障数据完整性,自动校验数据,减少人工错误,提升数据一致性和业务逻辑严谨性,本文介绍My... 目录1.引言2.NOT NULL——制定某列不可以存储NULL值2.UNIQUE——保证某一列的每一

深度解析Nginx日志分析与499状态码问题解决

《深度解析Nginx日志分析与499状态码问题解决》在Web服务器运维和性能优化过程中,Nginx日志是排查问题的重要依据,本文将围绕Nginx日志分析、499状态码的成因、排查方法及解决方案展开讨论... 目录前言1. Nginx日志基础1.1 Nginx日志存放位置1.2 Nginx日志格式2. 499

MySQL CTE (Common Table Expressions)示例全解析

《MySQLCTE(CommonTableExpressions)示例全解析》MySQL8.0引入CTE,支持递归查询,可创建临时命名结果集,提升复杂查询的可读性与维护性,适用于层次结构数据处... 目录基本语法CTE 主要特点非递归 CTE简单 CTE 示例多 CTE 示例递归 CTE基本递归 CTE 结

C#监听txt文档获取新数据方式

《C#监听txt文档获取新数据方式》文章介绍通过监听txt文件获取最新数据,并实现开机自启动、禁用窗口关闭按钮、阻止Ctrl+C中断及防止程序退出等功能,代码整合于主函数中,供参考学习... 目录前言一、监听txt文档增加数据二、其他功能1. 设置开机自启动2. 禁止控制台窗口关闭按钮3. 阻止Ctrl +

java如何实现高并发场景下三级缓存的数据一致性

《java如何实现高并发场景下三级缓存的数据一致性》这篇文章主要为大家详细介绍了java如何实现高并发场景下三级缓存的数据一致性,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 下面代码是一个使用Java和Redisson实现的三级缓存服务,主要功能包括:1.缓存结构:本地缓存:使

详解MySQL中JSON数据类型用法及与传统JSON字符串对比

《详解MySQL中JSON数据类型用法及与传统JSON字符串对比》MySQL从5.7版本开始引入了JSON数据类型,专门用于存储JSON格式的数据,本文将为大家简单介绍一下MySQL中JSON数据类型... 目录前言基本用法jsON数据类型 vs 传统JSON字符串1. 存储方式2. 查询方式对比3. 索引