分享一下我老师大神的人工智能教程!零基础,通俗易懂!http://blog.csdn.net/jiangjunshow
也欢迎大家转载本篇文章。分享知识,造福人民,实现我们中华民族伟大复兴!
1、Dom4j概述
dom4j is an easy to use, open source library for working with XML, XPath and XSLT on the Java platform using the Java Collections Framework and with full support for DOM, SAX and JAXP.
dom4j官方网址:dom4j
dom4j源码下载:dom4j download
本示例中,需要导入dom4j.jar包,才能引用dom4j相关类,dom4j源码和jar包,请见本示例【源码下载】或访问 dom4j
org.dom4j包,不仅包含创建xml的构建器类DocumentHelper、Element,而且还包含解析xml的解析器SAXReader、Element,包含类如下:
org.dom4j
org.dom4j.DocumentHelper;
org.dom4j.Element;
org.dom4j.io.SAXReader;
org.dom4j.io.XMLWriter;
org.dom4j.DocumentException;
sdk源码查看路径(google code)
创建和解析xml的效果图:
2、Dom4j 创建 XML
Dom4j,创建xml主要用到了org.dom4j.DocumentHelper、org.dom4j.Document、org.dom4j.io.OutputFormat、org.dom4j.io.XMLWriter
首先,DocumentHelper.createDocument(),创建 org.dom4j.Document 的实例 doc
接着,通过doc,设置xml属性doc.setXMLEncoding("utf-8")、doc.addElement("root")根节点,以及子节点等
然后,定义xml格式并输出,new XMLWriter(xmlWriter, outputFormat)
Code
/** Dom4j方式,创建 XML */ public String dom4jXMLCreate(){ StringWriter xmlWriter = new StringWriter(); Person []persons = new Person[3]; // 创建节点Person对象 persons[0] = new Person(1, "sunboy_2050", "http://blog.csdn.net/sunboy_2050"); persons[1] = new Person(2, "baidu", "http://www.baidu.com"); persons[2] = new Person(3, "google", "http://www.google.com"); try { org.dom4j.Document doc = DocumentHelper.createDocument(); doc.setXMLEncoding("utf-8"); org.dom4j.Element eleRoot = doc.addElement("root"); eleRoot.addAttribute("author", "homer"); eleRoot.addAttribute("date", "2012-04-25"); eleRoot.addComment("dom4j test"); int personsLen = persons.length; for(int i=0; i"person"); // 创建person节点,引用类为 org.dom4j.Element Element eleId = elePerson.addElement("id"); eleId.addText(persons[i].getId()+""); Element eleName = elePerson.addElement("name"); eleName.addText(persons[i].getName()); Element eleBlog = elePerson.addElement("blog"); eleBlog.addText(persons[i].getBlog()); } org.dom4j.io.OutputFormat outputFormat = new org.dom4j.io.OutputFormat(); // 设置xml输出格式 outputFormat.setEncoding("utf-8"); outputFormat.setIndent(false); outputFormat.setNewlines(true); outputFormat.setTrimText(true); org.dom4j.io.XMLWriter output = new XMLWriter(xmlWriter, outputFormat); // 保存xml output.write(doc); output.close(); } catch (Exception e) { e.printStackTrace(); } savedXML(fileName, xmlWriter.toString()); return xmlWriter.toString(); }
3、Dom4j 解析 XML
Dom4j,解析xml主要用到了org.dom4j.io.SAXReader、org.dom4j.Document、doc.getRootElement(),以及ele.getName()、ele.getText()等
首先,创建SAXReader的实例reader,读入xml字节流 reader.read(is)
接着,通过doc.getRootElement()得到root根节点,利用迭代器取得root下一级的子节点eleRoot.elementIterator()等
然后,得到解析的xml内容xmlWriter.append(xmlHeader)、xmlWriter.append(personsList.get(i).toString())
解析一:标准解析(Iterator 迭代)
Code
/** Dom4j方式,解析 XML */ public String dom4jXMLResolve(){ StringWriter xmlWriter = new StringWriter(); InputStream is = readXML(fileName); try { SAXReader reader = new SAXReader(); org.dom4j.Document doc = reader.read(is); List personsList = null; Person person = null; StringBuffer xmlHeader = new StringBuffer(); Element eleRoot = doc.getRootElement(); // 获得root根节点,引用类为 org.dom4j.Element String attrAuthor = eleRoot.attributeValue("author"); String attrDate = eleRoot.attributeValue("date"); xmlHeader.append("root").append("\t\t"); xmlHeader.append(attrAuthor).append("\t"); xmlHeader.append(attrDate).append("\n"); personsList = new ArrayList(); // 获取root子节点,即person Iterator iter = eleRoot.elementIterator(); for(; iter.hasNext(); ) { Element elePerson = (Element)iter.next(); if("person".equals(elePerson.getName())){ person = new Person(); // 获取person子节点,即id、name、blog Iterator innerIter = elePerson.elementIterator(); for(; innerIter.hasNext();) { Element ele = (Element)innerIter.next(); if("id".equals(ele.getName())) { String id = ele.getText(); person.setId(Integer.parseInt(id)); } else if("name".equals(ele.getName())) { String name = ele.getText(); person.setName(name); } else if("blog".equals(ele.getName())) { String blog = ele.getText(); person.setBlog(blog); } } personsList.add(person); person = null; } } xmlWriter.append(xmlHeader); int personsLen = personsList.size(); for(int i=0; icatch (DocumentException e) { e.printStackTrace(); } catch (Exception e) { e.printStackTrace(); } return xmlWriter.toString(); }
运行结果:
解析二:选择性解析(XPath路径)
Dom4j+XPath,选择性只解析id,doc.selectNodes("//root//person//id")
Code
/** Dom4j方式,解析 XML(方式二) */ public String dom4jXMLResolve2(){ StringWriter xmlWriter = new StringWriter(); InputStream is = readXML(fileName); try { org.dom4j.io.SAXReader reader = new org.dom4j.io.SAXReader(); org.dom4j.Document doc = reader.read(is); List personsList = null; Person person = null; StringBuffer xmlHeader = new StringBuffer(); Element eleRoot = doc.getRootElement(); // 获得root根节点,引用类为 org.dom4j.Element String attrAuthor = eleRoot.attributeValue("author"); String attrDate = eleRoot.attributeValue("date"); xmlHeader.append("root").append("\t\t"); xmlHeader.append(attrAuthor).append("\t"); xmlHeader.append(attrDate).append("\n"); personsList = new ArrayList(); @SuppressWarnings("unchecked") List idList = (List) doc.selectNodes("//root//person//id"); // 选择性获取全部id Iterator idIter = idList.iterator(); while(idIter.hasNext()){ person = new Person(); Element idEle = (Element)idIter.next(); String id = idEle.getText(); person.setId(Integer.parseInt(id)); personsList.add(person); } xmlWriter.append(xmlHeader); int personsLen = personsList.size(); for(int i=0; i"id = ").append(personsList.get(i).getId()+"").append("\n"); } } catch (DocumentException e) { e.printStackTrace(); } catch (Exception e) { e.printStackTrace(); } return xmlWriter.toString(); }
注:借助 XPath 解析 XML 时,需要导入 jaxen;本示例需要导入的是最新的jaxen包jaxen-1.1.3.jar,可以下载本示例下面【源码下载】或 访问 jaxen jar
Jaxen is an open source XPath library written in Java. It is adaptable to many different object models, including DOM, XOM, dom4j, and JDOM. Is it also possible to write adapters that treat non-XML trees such as compiled Java byte code or Java beans as XML, thus enabling you to query these trees with XPath too.
jaxen 官方网址:jaxen
jaxen下载jar包:jaxen jar 或 jaxen jar
jaxen源码查看:jaxen src 或 jaxen trunk
运行结果:
4、Person类
请参见前面博客 Android 创建与解析XML(二)—— Dom方式 【4、Person类】
源码下载
参考推荐:
dom4j(官方网站)
dom4j src(源码下载)
dom4j src and jar(google code)
jaxen(jaxen 官方网址)
jaxen jar(jaxen jar包下载)
jaxen src(jaxen在线源码)
dom4j 解析 XML(IBM)
dom4j和XPath解析XML
dom4j 属性值回车换行问题
我们对Markdown编辑器进行了一些功能拓展与语法支持,除了标准的Markdown编辑器功能,我们增加了如下几点新功能,帮助你用它写博客:
撤销:Ctrl/Command + Z
重做:Ctrl/Command + Y
加粗:Ctrl/Command + B
斜体:Ctrl/Command + I
标题:Ctrl/Command + Shift + H
无序列表:Ctrl/Command + Shift + U
有序列表:Ctrl/Command + Shift + O
检查列表:Ctrl/Command + Shift + C
插入代码:Ctrl/Command + Shift + K
插入链接:Ctrl/Command + Shift + L
插入图片:Ctrl/Command + Shift + G
直接输入1次#,并按下space后,将生成1级标题。
输入2次#,并按下space后,将生成2级标题。
以此类推,我们支持6级标题。有助于使用TOC
语法后生成一个完美的目录。
强调文本 强调文本
加粗文本 加粗文本
标记文本
删除文本
引用文本
H2O is是液体。
210 运算结果是 1024.
链接: link.
当然,我们为了让用户更加便捷,我们增加了图片拖拽功能。
去博客设置页面,选择一款你喜欢的代码片高亮样式,下面展示同样高亮的 代码片
.
// An highlighted block var foo = 'bar';
一个简单的表格是这么创建的:
项目 | Value |
---|---|
电脑 | $1600 |
手机 | $12 |
导管 | $1 |
使用:---------:
居中
使用:----------
居左
使用----------:
居右
第一列 | 第二列 | 第三列 |
---|---|---|
第一列文本居中 | 第二列文本居右 | 第三列文本居左 |
SmartyPants将ASCII标点字符转换为“智能”印刷标点HTML实体。例如:
TYPE | ASCII | HTML |
---|---|---|
Single backticks | 'Isn't this fun?' |
‘Isn’t this fun?’ |
Quotes | "Isn't this fun?" |
“Isn’t this fun?” |
Dashes | -- is en-dash, --- is em-dash |
– is en-dash, — is em-dash |
一个具有注脚的文本。2
Markdown将文本转换为 HTML。
您可以使用渲染LaTeX数学表达式 KaTeX:
Gamma公式展示 Γ ( n ) = ( n − 1 ) ! ∀ n ∈ N \Gamma(n) = (n-1)!\quad\forall n\in\mathbb N Γ(n)=(n−1)!∀n∈N 是通过欧拉积分
Γ ( z ) = ∫ 0 ∞ t z − 1 e − t d t   . \Gamma(z) = \int_0^\infty t^{z-1}e^{-t}dt\,. Γ(z)=∫0∞tz−1e−tdt.
你可以找到更多关于的信息 LaTeX 数学表达式here.
gantt
dateFormat YYYY-MM-DD
title Adding GANTT diagram functionality to mermaid
section 现有任务
已完成 :done, des1, 2014-01-06,2014-01-08
进行中 :active, des2, 2014-01-09, 3d
计划一 : des3, after des2, 5d
计划二 : des4, after des3, 5d
可以使用UML图表进行渲染。 Mermaid. 例如下面产生的一个序列图::
这将产生一个流程图。:
我们依旧会支持flowchart的流程图:
如果你想尝试使用此编辑器, 你可以在此篇文章任意编辑。当你完成了一篇文章的写作, 在上方工具栏找到 文章导出 ,生成一个.md文件或者.html文件进行本地保存。
如果你想加载一篇你写过的.md文件或者.html文件,在上方工具栏可以选择导入功能进行对应扩展名的文件导入,
继续你的创作。
mermaid语法说明 ↩︎
注脚的解释 ↩︎