TinyXmlParser

码农软件 · 软件分类 · 网页开发工具 · 2019-03-21 19:28:54

软件介绍

优点:

高效、简单、易用的Xml解析器。

学习时间,分分钟。

支持中文标签名与属性名,支持下划线,减号等分隔符。

解析速度超过,查找速度超快,支持格式化。

缺点:不支持Xml Schema,DTD校验。

Maven引用坐标:

<dependency>
<groupId>org.tinygroup</groupId>
<artifactId>org.tinygroup.xmlparser</artifactId>
<version>0.1.0-SNAPSHOT</version>
</dependency>

解析下面xml

<?xml version="1.0"?>
<students>
    <student>
        <name>John</name>
        <grade>B</grade>
        <age>12</age>
    </student>
    <student>
        <name>Mary</name>
        <grade>A</grade>
        <age>11</age>
    </student>
    <student>
        <name>Simon</name>
        <grade>A</grade>
        <age>18</age>
    </student>
</students>

示例代码:

public class TestXmlParser {
    public static void main(String[] args) throws Throwable {
        File file = new File("E:/test/students.xml ");
        XmlStringParser parser = new XmlStringParser();
        XmlDocument document = parser.parse(IOUtils.readFromInputStream(
                new FileInputStream(file), "utf-8"));
        printStudents(document.getRoot());
    }
    private static void printStudents(XmlNode studentsNode) {
        for(XmlNode studentNode:studentsNode.getSubNodes("student")){
            printStuent(studentNode);
        }
    }
    private static void printStuent(XmlNode studentNode) {
        printSubTagByName(studentNode,"name");
        printSubTagByName(studentNode,"grade");
        printSubTagByName(studentNode,"age");
    }
    private static void printSubTagByName(XmlNode studentNode,String tagName) {
        System.out.println( studentNode.getSubNode(tagName).getContent());
    }
}

格式化示例:

XmlDocument doc;
doc = new XmlStringParser()
        .parse("aaa");
XmlFormater f = new XmlFormater();
System.out.println(f.format(doc));

运行结果:

aaa

性能测试:

构建下面的节点规模:

	HtmlNode node = null;

	public NameFilterTest() {
		node = new HtmlNode("root");
		for (int i = 0; i < 60; i++) {
			HtmlNode a = node.addNode(new HtmlNode("a" + i));
			for (int j = 0; j < 60; j++) {
				HtmlNode b = a.addNode(new HtmlNode("b" + j));
				for (int k = 0; k < 60; k++) {
					b.addNode(new HtmlNode("c" + k));
				}
			}
		}
	}

也就是节点数60+60*60+60*60*60个节点数时,进行下面的查找:

		long t21 = System.currentTimeMillis();
		FastNameFilter fast = new FastNameFilter(node);
		long t22 = System.currentTimeMillis();
		System.out.println("fast初始化用时" + (t22 - t21));
		long t1 = System.currentTimeMillis();
		String nodeName = null;
		for (int x = 0; x < 10000; x++) {
			nodeName = fast.findNode("b6").toString();
		}
		// System.out.println(nodeName);
		long t2 = System.currentTimeMillis();
		System.out.println("FastNameFilter用时" + (t2 - t1));

运行结果:

fast初始化用时130
FastNameFilter用时450

也就是说在219661个节点中,查找指定节点10000次,只用时450ms。

更多详细信息可以前往软件开发者博客:http://my.oschina.net/tinyframework/

本文地址:https://codercto.com/soft/d/1857.html

数学规划

数学规划

黄红选 / 清华大学出版社 / 2006-3 / 45.00元

《数学规划》以数学规划为对象,从理论、算法和计算等方面介绍,分析和求解常见的最优化问题的一些方法,全书共分8章,其中第l章介绍了数学规划的实例、模型以及在分析最优化问题时所涉及的基础知识,第2章至第8章分别讨论了凸分析、线性规划、无约束优化、约束优化、多目标规划、组合优化和整数规划以及全局优化等七个方面的内容,此外,书中每章的最后一节给出了一些习题,书末列出了参考文献和索引。《数学规划》可作为应用......一起来看看 《数学规划》 这本书的介绍吧!

html转js在线工具
html转js在线工具

html转js在线工具

正则表达式在线测试
正则表达式在线测试

正则表达式在线测试

HEX HSV 转换工具
HEX HSV 转换工具

HEX HSV 互换工具