??xml version="1.0" encoding="utf-8" standalone="yes"?>
华ؓ一般是周五面试,其实我几乎没d为面?有几ơ华为打电话q来,我恰好有其他的面?所以去不了,q次反正闲着也是闲着,所?在上午接到电话后,下午坐公车去?
我住的地方去华ؓ基地比较q?坐公车都?元RMB,下了?打了电话,l过电话指点,l于扑ֈ了面试地?外面好冷,q去׃怎么冷了,没说别的,拿v试卷开始做?
题目的难度在我预料之?依我的水q也拿?0分左右的样子(一般的公司我可以拿80以上,^_^),
令我意外的是,W试完后,面试技术的考官q没怎么看我的答?而是直接和我聊v技术方面的东西,问的很详l?特别是问到具体做q的目?问的比较仔细,要不是我真的做过,非穿帮不?呵呵,问了目,开始问技?只要我简历上写的技?他都会问的很仔细,有几个地?我记得不是很清楚,也就打哈哈过?他也没说什?p样问了大概一个多钟头,他才?好了,你在q等?p?我好不容易许了一口气,心里也没什么底,{了10分钟的样?来了一个领导模L人物,拿了本笔记本,坐在我旁边,和我聊v了一些看似琐的东西,其实在暗里考察的问?M感觉q过的去,完了,他说,我考虑?p?出去的时候我和面试我技术的考官一起出?他问我感觉怎么?我说q行,他说q几天会电话通知?呵呵,当时应该问下他机会大?可惜?现在也只好在家等l果?不过中博那边如果要我马上上班的话,我还真不好抉?因ؓ中博那边是做外包,而且要出?虽然薪资有点׃h,但毕竟感觉没q华为好.
׃的日子的比较枯?闲着没事随便写??呵呵,很晚?要睡?...
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>
我们可以通过多种Ҏ来操作XML文档Q这些方法返回java里标准的q代器(IteratorsQ。例如:
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ؓ"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树状l构中的Document或者Q意的节点QNodeQ(例如QAttributeQElement 或?ProcessingInstruction{)。它可以使在文档中复杂的操作仅通过一行代码就可以完成。例如:
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你可以使用下面的代码:
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他会通过一个一个的例子引导你学习?/p>
快速遍历(Fast LoopingQ?/p>
如果你不得不遍历一个非常大的XML文Q然后才L行,我们你用快速遍历方法(fast looping methodQ,它可以避免ؓ每一个@环的节点创徏一个P代器对象,如下所C:
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行了示范:
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()Ҏ?/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()Ҏ把它转化Z个默认的XML字符Ԍ
Document document = ...;
String text = document.asXML();
如果你有一些XML内容的字W串表示Q你可以通过DocumentHelper.parseText()Ҏ它重新转化为文档(DocumentQ对象:
String text = "
Document document = DocumentHelper.parseText(text);
通过XSLT样式化文(DocumentQ?/p>
使用Sun公司提供的JAXP APIXSLT 应用到文(DocumentQ上是很单的。它允许你用Q何的XSLT引擎Q例如:Xalan或SAXON{)来开发。下面是一个用JAXP创徏一个{化器QtransformerQ,然后它应用到文档(DocumentQ上的例子:
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;
}
}
![]() |