??xml version="1.0" encoding="utf-8" standalone="yes"?>
(tng) (tng) (tng) (tng) (tng) (tng)华ؓ(f)一般是周五面试,其实我几乎没d为面?有几ơ华为打?sh)话q来,我恰好有其他的面?所以去不了(jin),q次反正闲着也是闲着,所?在上午接到电(sh)话后,下午坐公车去?
(tng) (tng) (tng) (tng) (tng) (tng)我住的地方去华ؓ(f)基地比较q?坐公车都?元RMB,下了(jin)?打了(jin)?sh)?l过?sh)话指?l于扑ֈ?jin)面试地?外面好冷,q去׃怎么冷了(jin),没说别的,拿v试卷开始做?
(tng) (tng) (tng) (tng) (tng) (tng)题目的难度在我预料之?依我的水q也拿?0分左右的样子(一般的公司我可以拿80以上,^_^),
令我意外的是,W试完后,面试技术的考官q没怎么看我的答?而是直接和我聊v技术方面的东西,问的很详l?特别是问到具体做q的目?问的比较仔细,要不是我真的做过,非穿帮不?呵呵,问了(jin)目,开始问技?只要我简历上写的技?他都?x)问的很仔?有几个地?我记得不是很清楚,也就打哈哈过?他也没说什?p样问?jin)大概一个多钟头,他才?好了(jin),你在q等?p?我好不容易许?jin)一口气,?j)里也没什么底,{了(jin)10分钟的样?来了(jin)一个领导模L(fng)人物,拿了(jin)本笔记本,坐在我旁边,和我聊v?jin)一些看似琐的东西,其实在暗里考察的问?M感觉q过的去,完了(jin),他说,我考虑?p?出去的时候我和面试我技术的考官?sh)起出?他问我感觉怎么?我说q行,他说q几天会(x)?sh)话通知?呵呵,当时应该问下他机?x)大?可惜?现在也只好在家等l果?不过中博那边如果要我马上上班的话,我还真不好抉?因ؓ(f)中博那边是做外包,而且要出?虽然薪资有点׃h,但毕竟感觉没q华为好.
(tng) (tng) (tng) (tng) (tng) (tng)׃的日子的比较枯?闲着没事随便写??呵呵,很晚?要睡?...
Parsing XML
或许你想要做的第一件事情就是解析一个某U类型的XML文档Q用dom4j很容易做到。请看下面的C代码Q?/p>
import java.net.URL;
import org.dom4j.Document;
import org.dom4j.DocumentException;
import org.dom4j.io.SAXReader;
public class Foo {
public Document parse(URL url) throws DocumentException {
SAXReader reader = new SAXReader();
Document document = reader.read(url);
return document;
}
}
使用q代器(IteratorsQ?/p>
我们可以通过多种Ҏ(gu)来操作XML文Q这些方法返回java里标准的q代器(IteratorsQ。例如:(x)
public void bar(Document document) throws DocumentException {
Element root = document.getRootElement();
//q代根元素下面的所有子元素
for ( Iterator i = root.elementIterator(); i.hasNext(); ) {
Element element = (Element) i.next();
//处理代码
}
//q代根元素下面名UCؓ(f)"foo"的子元素
for ( Iterator i = root.elementIterator( "foo" ); i.hasNext(); ) {
Element foo = (Element) i.next();
//处理代码
}
// q代根元素的属性attributesQ元?br />for ( Iterator i = root.attributeIterator(); i.hasNext(); ) {
Attribute attribute = (Attribute) i.next();
// do something
}
}
强大的XPathD
在dom4j中XPath可以表示出在XML?wi)状l构中的Document或者Q意的节点QNodeQ(例如QAttributeQElement 或?ProcessingInstruction{)(j)。它可以使在文中复杂的操作仅通过一行代码就可以完成。例如:(x)
public void bar(Document document) {
List list = document.selectNodes( "http://foo/bar" );
Node node = document.selectSingleNode( "http://foo/bar/author" );
String name = node.valueOf( "@name" );
}
如果你想得到一个XHTML文档中的所有超文本链接Qhypertext linksQ你可以使用下面的代码:(x)
public void findLinks(Document document) throws DocumentException {
List list = document.selectNodes( "http://a/@href" );
for (Iterator iter = list.iterator(); iter.hasNext(); ) {
Attribute attribute = (Attribute) iter.next();
String url = attribute.getValue();
}
}
如果你需要关于XPath语言的Q何帮助,我们强烈推荐q个站点Zvon tutorial他会(x)通过一个一个的例子引导你学?fn)?/p>
快速遍历(F(tun)ast LoopingQ?/p>
如果你不得不遍历一个非常大的XML文档Q然后才L行,我们你用快速遍历方法(fast looping methodQ,它可以避免ؓ(f)每一个@环的节点创徏一个P代器对象,如下所C:(x)
public void treeWalk(Document document) {
treeWalk( document.getRootElement() );
}
public void treeWalk(Element element) {
for ( int i = 0, size = element.nodeCount(); i < size; i++ ) {
Node node = element.node(i);
if ( node instanceof Element ) {
treeWalk( (Element) node );
}
else {
// do something....
}
}
}
生成一个新的XML文对象
在dom4j中你可能常常希望用程序生成一个XML文对象Q下面的E序Zq行?jin)示范?x)
import org.dom4j.Document;
import org.dom4j.DocumentHelper;
import org.dom4j.Element;
public class Foo {
public Document createDocument() {
Document document = DocumentHelper.createDocument();
Element root = document.addElement( "root" );
Element author1 = root.addElement( "author" )
.addAttribute( "name", "James" )
.addAttribute( "location", "UK" )
.addText( "James Strachan" );
Element author2 = root.addElement( "author" )
.addAttribute( "name", "Bob" )
.addAttribute( "location", "US" )
.addText( "Bob McWhirter" );
return document;
}
}
一个文对象写入文件中
一个文对象写入Writer对象的一个简单快速的途径是通过write()Ҏ(gu)?/p>
FileWriter out = new FileWriter( "foo.xml" );
document.write( out );
如果你想改变输出文g的排版格式,比如你想要一个漂亮的格式或者是一个紧凑的格式Q或者你想用Writer 对象或者OutputStream 对象来操作,那么你可以用XMLWriter cR?/p>
import org.dom4j.Document;
import org.dom4j.io.OutputFormat;
import org.dom4j.io.XMLWriter;
public class Foo {
public void write(Document document) throws IOException {
// 写入文g
XMLWriter writer = new XMLWriter(
new FileWriter( "output.xml" )
);
writer.write( document );
writer.close();
// 以一U优雅的格式写入System.out对象
OutputFormat format = OutputFormat.createPrettyPrint();
writer = new XMLWriter( System.out, format );
writer.write( document );
// 以一U紧凑的格式写入System.out对象
format = OutputFormat.createCompactFormat();
writer = new XMLWriter( System.out, format );
writer.write( document );
}
}
转化为字W串Q或者从字符串{?/p>
如果你有一个文档(DocumentQ对象或者Q何一个节点(NodeQ对象的引用QreferenceQ,象属性(AttributeQ或者元素(ElementQ,你可以通过asXML()Ҏ(gu)把它转化Z个默认的XML字符Ԍ(x)
Document document = ...;
String text = document.asXML();
如果你有一些XML内容的字W串表示Q你可以通过DocumentHelper.parseText()Ҏ(gu)它重新转化为文(DocumentQ对象:(x)
String text = "
Document document = DocumentHelper.parseText(text);
通过XSLT样式化文(DocumentQ?/p>
使用Sun公司提供的JAXP APIXSLT 应用到文(DocumentQ上是很单的。它允许你用Q何的XSLT引擎Q例如:(x)Xalan或SAXON{)(j)来开发。下面是一个用JAXP创徏一个{化器QtransformerQ,然后它应用到文(DocumentQ上的例子:(x)
import javax.xml.transform.Transformer;
import javax.xml.transform.TransformerFactory;
import org.dom4j.Document;
import org.dom4j.io.DocumentResult;
import org.dom4j.io.DocumentSource;
public class Foo {
public Document styleDocument(
Document document,
String stylesheet
) throws Exception {
// 使用 JAXP 加蝲转化?br />TransformerFactory factory = TransformerFactory.newInstance();
Transformer transformer = factory.newTransformer(
new StreamSource( stylesheet )
);
// 现在来样式化一个文档(DocumentQ?br />DocumentSource source = new DocumentSource( document );
DocumentResult result = new DocumentResult();
transformer.transform( source, result );
// q回l过样式化的文QDocumentQ?br />Document transformedDoc = result.getDocument();
return transformedDoc;
}
}
![]() |