19 标签:xml或者html
1 标签:xml或者html
1.1 使用XmlSlurper解析xml
groovy处理xml非常容易。XmlSlurper 类用来处理xml。在处理xml方面,还有其他的处理方式,但是XmlSlurper 处理效率更加的高效,并且灵活性很好。
XmlSlurper 执行parseText后返回GPathResult 对象。能够使用GPath 表达式来访问xml树中的各个层级节点。
用点(.)来读取需要的子节点,并且使用@读取属性值。
|
package xml class XmlSlurperTest { static main(args) { def xmldocument=''' <persons> <person age="3"> <name> <firstname sex="男">zuoys</firstname> <lastname>yaoyuan2</lastname> </name> </person> <person age="4"> <name> <firstname>yang</firstname> <lastname>jack</lastname> </name> </person> </persons> '''; //解析并读取该xml def persons = new XmlSlurper().parseText(xmldocument); /** * 当然,也可以从一个磁盘中的文件中读取,如 * def persons = new XmlSlurper().parse(new File('data/plan.xml')) */ def allRecords = persons.person.size(); println("xml文档中person的数量是:$allRecords"); def person = persons.person[0]; println("person'name下的所有元素(不含属性)的值:${person.name}"); for (p in persons.person) { println("${p.name.firstname.text()},${p.name.lastname.text()} 是 ${p.@age} 岁"); } } } |
输出
|
xml文档中person的数量是:2 person'name下的所有值:zuoysyaoyuan2 zuoys,yaoyuan2 是 3 岁 yang,jack 是 4 岁 |
1.2 使用MarkupTemplateEngine生成标签
在Groovy2.3中,MarkupTemplateEngine 支持生成类似xml的标记(XML, XHTML, HTML5等),但是,其通常被用来生成任意的文本。
静态编译非常快,并且支持国际化,同时也支持模板(template)。
|
package xml import groovy.text.markup.MarkupTemplateEngine import groovy.text.markup.TemplateConfiguration import template.Task class MarkupTemplateEngineTest { static main(args) { String xml_template = '''xmlDeclaration() tasks { tasks.each { task (summary:it.summary,duration:it.duration); }; }; '''; String html_template=''' yieldUnescaped '<!DOCTYPE html>'; html(lang:'en') { head { meta('http-equiv':'"Content-Type" content="text/html; charset=utf-8"'); title('My page'); }; body { p('这是一个html例子'); }; }; '''; def values = [tasks:[ new Task(summary:"java",duration:4), new Task(summary:"groovy",duration:12) ] ]; TemplateConfiguration config = new TemplateConfiguration(); def engine = new MarkupTemplateEngine(config); def template1 = engine.createTemplate(xml_template); def template2 = engine.createTemplate(html_template); println("===xml输出:"); println template1.make(values); println("===html输出:"); println template2.make(values); } } |
输出
|
===xml输出: <?xml version='1.0'?> <tasks><task summary='java' duration='4'/><task summary='groovy' duration='12'/></tasks> ===html输出: <!DOCTYPE html><html lang='en'><head><meta http-equiv='"Content-Type" content="text/html; charset=utf-8"'/><title>My page</title></head><body><p>这是一个html例子</p></body></html> |
Templates support includes.
1.3 使用MarkupBuilder创建标签(xml)文件
MarkupBuilder 是一个很老的builder,例子如下:
|
package xml import groovy.xml.MarkupBuilder /** * 生产xml * @author zuoys * */ class MarkupWriter { static main(args) { def date = new Date(); StringWriter writer = new StringWriter(); MarkupBuilder builder = new MarkupBuilder(writer); builder.tasks { for (i in 1..3) { task { summary(value:"Test $i"); description(value:"Description $i"); duedate(value:"${date.format('yyyy-MM-dd')}"); }; } }; println(writer.toString()); } } |
输出
|
<tasks> <task> <summary value='Test 1' /> <description value='Description 1' /> <duedate value='2016-07-24' /> </task> <task> <summary value='Test 2' /> <description value='Description 2' /> <duedate value='2016-07-24' /> </task> <task> <summary value='Test 3' /> <description value='Description 3' /> <duedate value='2016-07-24' /> </task> </tasks> |
builder.tasks {:生成父节点。
task {生成二级子节点。
summary(value:"Test $i");:使用构造方法来创建子节点。
使用MarkupBuilder时,这些都是在运行时构建的。
也可以使用map,如下:
|
package xml import groovy.xml.MarkupBuilder class MarkupWriterMap { static main(args) { Map map = [zuo:"zuoys",yang:"yangyang"]; def date = new Date(); StringWriter writer = new StringWriter(); MarkupBuilder builder = new MarkupBuilder(writer); builder.tasks { map.each {key,myvalue -> person { firstname(value:"$key"); lastname(value:"$myvalue"); }; }; }; println(writer.toString()); } } |
输出
|
<tasks> <person> <firstname value='zuo' /> <lastname value='zuoys' /> </person> <person> <firstname value='yang' /> <lastname value='yangyang' /> </person> </tasks> |
也可以使用builder来创建合法的html。
|
package xml import groovy.xml.MarkupBuilder class MarkupHtml { static main(args) { Map map = [zuo:"zuoys",yang:"yangyang"]; def date = new Date(); StringWriter writer = new StringWriter(); MarkupBuilder builder = new MarkupBuilder(writer); builder.html { head { title("yaoyuan2.com"); }; body { div (class:"strike"); p ("this is line"); }; }; println(writer.toString()); } } |
输出
|
<html> <head> <title>yaoyuan2.com</title> </head> <body> <div class='strike' /> <p>this is line</p> </body> </html> |
19 标签:xml或者html的更多相关文章
- Jersey(1.19.1) - XML Support
As you probably already know, Jersey uses MessageBodyWriters and MessageBodyReaders to parse incomin ...
- tomcat与springmvc 结合 之---第19篇(下,补充) springmvc 加载.xml文件的bean标签的过程
writedby 张艳涛,上一篇写了springmvc对<mvc:annoXXXX/>标签的解析过程,其实是遗漏重要的细节,因为理解的不深入吧 今天接着解析<bean>标签 & ...
- 读取只包含标签的xml
什么是XML XML是可扩展标记语言(Extensible Markup Language)的缩写,其中标记是关键部分.用户可以创建内容,然后使用限定标记标记它,从而使每个单词.短语或块成为可识别.可 ...
- tomcat与springmvc 结合 之---第19篇 springmvc 加载.xml文件的bean 过程
writedby 张艳涛,看springmvc 的源码太难了,怎么办, 这篇文章主要分析了看透springmvc的第9章结尾的 如何解析xml 命名空间标签 <?xml version=&quo ...
- 转:在java中使用dom4j解析xml
JAVA 使用Dom4j 解析XML Java DOM4J Parser - Parse XML Document Dom4j下载及使用Dom4j读写XML简介 在java中使用dom4j解析xml ...
- javaweb学习总结(二十七)——jsp简单标签开发案例和打包
一.开发标签库 1.1.开发防盗链标签 1.编写标签处理器类:RefererTag.java 1 package me.gacl.web.simpletag; 2 3 import java.io.I ...
- 9.XML文件解析
一.XML简介 XML(EXtensible Markup Language),可扩展标记语言 特点:XML与操作系统.编程语言的开发平台无关 实现不同系统之间的数据交换 作用:数据交互 配置应用程序 ...
- Java是如何解析xml文件的(DOM)
Java解析xml文件 在Java程序中读取xml文件的过程也称为"解析xml文件": 解析的目的: 获取 节点名和节点值 获取 属性名.属性值. 四中解析方式: DOM SAX ...
- 第70节:Java中xml和tomcat
第70节:Java中xml和tomcat 前言: 哭着也要看完,字数: jdbc crud - statement dao java.sql.Driver The interface that eve ...
随机推荐
- C++中如何计算程序运行的时间 (转载)
转载地址:http://blog.csdn.net/wuxuguang123/article/details/8130081 一 个程序的功能通常有很多种方法来实现,怎么样的程序才算得上最优呢?举个例 ...
- 基于BASYS2的VHDL程序——数字钟(最终版)
转载请注明原地址:http://www.cnblogs.com/connorzx/p/3674178.html 调时电路正常工作.一切正常.发现做FPGA还是得从数电的思路思考,设置一个预置使能端,预 ...
- MySQL丨分页查询
直奔主题 一.sql语句:select * from table limit startPageNum,everyPageNum 1)语句解析: table:你要查询的表 startPageNum:从 ...
- SQL Server中误删除数据的恢复
SQL Server中误删除数据的恢复本来不是件难事,从事务日志恢复即可.但是,这个恢复需要有两个前提条件: 1. 至少有一个误删除之前的数据库完全备份. 2. 数据库的恢复模式(Recovery m ...
- mysql:mysql安装及一些配置和图形界面介绍
关于mysql,我使用的不多,这次记录是在学习一位大牛的demo的契机下完成的.包括前面记录到的sqlserver的一些知识点,也是在新的项目组中协助时候学习记录的.希望通过记录加深印象和帮助后来者. ...
- atof,atoi,atol,strtod,strtol,strtoul
字符串处理函数 atof 将字串转换成浮点型数 atoi 字符串转换成整型数 atol 函数名: atol 功 能: 把字符串转换成长整型数 用 法: long atol(const char *np ...
- 下载android sdk
- 非侵入式JavaScript(Unobtrusive javaScript)理解
转载自 https://my.oschina.net/leegq/blog/279750 在Web的早期阶段,也就是在jQuery出现以前,在同一个文件中混杂JavaScript代码和HTML标记是非 ...
- Visual Studio 2010下WorldWind编译问题集合
首先:获取WORLDWIND最新代码——建议不要直接下载源代码包进行编译,一是因为它并不是最新版本的代码,WW的代码最近经常更新:二是缺很多依赖的类库.建议用TortoiseSVN客户端从source ...
- lua中文教程【高级知识】
一.编译和运行和调试 1.lua和其他解释型语言一样,先转换成为中间码再执行 2.dofile和loadfile的区别:loadfile编译返回不执行,返回错误代码:dofile执行,返回错误信息 3 ...