关于eclipse里,xml文件的读取与参数的输出。

长智齿的程序媛 2015-10-19 02:46:21
我把xml文件的数据存进了map里,方法和相关文件如下。

问题是 比如 我想要输出:page下的source和dest和pageno,但是在此xml文件下有多个page。怎么保障输出的source和dest和pageno是在同一个page节点里的?也就是怎么保证对应关系,不出错。谢谢各位~~~


<?xml version="1.0" encoding="UTF-8"?>

<Root>
<Merge>true</Merge>
<DestName>destName</DestName>
<Page>
<Source>source1</Source>
<Dest>dest1</Dest>
<PageNo>1</PageNo>
<Additional>
<FileName>filename1</FileName>
<Position>1</Position>
</Additional>
<Additional>
<FileName>filename2</FileName>
<Position>2</Position>
</Additional>
<Additional>
<FileName>filename3</FileName>
<Position>3</Position>
</Additional>
</Page>
<Page>
<Source>source2</Source>
<Dest>dest2</Dest>
<PageNo>2</PageNo>
<Additional>
<FileName>filename2</FileName>
<Position>2</Position>
</Additional>
<Additional>
<FileName>filename4</FileName>
<Position>4</Position>
</Additional>
<Additional>
<FileName>filename6</FileName>
<Position>6</Position>
</Additional>
</Page>
<Page>
<Source>source3</Source>
<Dest>dest3</Dest>
<PageNo>3</PageNo>
<Additional>
<FileName>filename3</FileName>
<Position>3</Position>
</Additional>
<Additional>
<FileName>filename6</FileName>
<Position>6</Position>
</Additional>
<Additional>
<FileName>filename9</FileName>
<Position>9</Position>
</Additional>
</Page>
</Root>




Java代码:




package cn.micheal;


import java.util.ArrayList;
import java.util.HashMap;
import java.util.Iterator;
import java.util.List;
import java.util.Map;

import org.dom4j.Document;
import org.dom4j.Element;


public class ReadXml {
@SuppressWarnings({ "rawtypes" })
public static Map<String, Object> Dom2Map(Document doc){
Map<String, Object> map = new HashMap<String, Object>();
if(doc == null)
return map;
Element root = doc.getRootElement();
for (Iterator iterator = root.elementIterator(); iterator.hasNext();) {
Element e = (Element) iterator.next();
List list = e.elements();
if(list.size() > 0){
map.put(e.getName(), Dom2Map(e));
}else
map.put(e.getName(), e.getText());
}
return map;
}
@SuppressWarnings({ "unchecked", "rawtypes" })
public static Map Dom2Map(Element e){
Map map = new HashMap();
List list = e.elements();
if(list.size() > 0){
for (int i = 0;i < list.size(); i++) {
Element iter = (Element) list.get(i);
List mapList = new ArrayList();

if(iter.elements().size() > 0){
Map m = Dom2Map(iter);
if(map.get(iter.getName()) != null){
Object obj = map.get(iter.getName());
if(!obj.getClass().getName().equals("java.util.ArrayList")){
mapList = new ArrayList();
mapList.add(obj);
mapList.add(m);
}
if(obj.getClass().getName().equals("java.util.ArrayList")){
mapList = (List) obj;
mapList.add(m);
}
map.put(iter.getName(), mapList);
}else
map.put(iter.getName(), m);
}
else{
if(map.get(iter.getName()) != null){
Object obj = map.get(iter.getName());
if(!obj.getClass().getName().equals("java.util.ArrayList")){
mapList = new ArrayList();
mapList.add(obj);
mapList.add(iter.getText());
}
if(obj.getClass().getName().equals("java.util.ArrayList")){
mapList = (List) obj;
mapList.add(iter.getText());
}
map.put(iter.getName(), mapList);
}else
map.put(iter.getName(), iter.getText());
}
}
}else
map.put(e.getName(), e.getText());
return map;
}



}



...全文
285 4 打赏 收藏 转发到动态 举报
AI 作业
写回复
用AI写文章
4 条回复
切换为时间正序
请发表友善的回复…
发表回复
  • 打赏
  • 举报
回复
@无法显示此用户
  • 打赏
  • 举报
回复
我的描述可能不准确了,有点片面了。 整个流程是这样的。有三个文件夹 Source。process。finished。 Source中不定时会有前台保存进来的zip压缩包,每个zip压缩包里会有word或者excel或者图片等格式的文件,还有一个xml文件。但是每个zip压缩包里的文件内容和个数是不一样的,相同的,xml配置文件也不一样。我要做的是解析把zip解压缩到process文件夹中,读取它特定的xml文件,根据配置信息,将word和其他的文件转换生成pdf /... 问题是:我不知道这个过程怎么写代码实现。就是读取xml配置信息。 转换描述文件xml的 <?xml version="1.0" encoding="utf-8"?> <Root> <Merge>是否合并为一个PDF文档:true,合并为一个文档,false,不合并为一个文档</Merge> <DestName>如果合并为一个PDF文档,则此处为目标文件名</DestName> <!-- 当有多个文件需要转换时,会有多个Page节点 --> <Page> <Source>原文件名</Source> <Dest>目标文件名,当不合并为一个文档时有效</Dest> <PageNo>顺序,当需要将文档合并为一个PDF文档时,此字段用来设定在文档中所在页号</PageNo> <!-- 如果有多个附加文件,会有多个Additional节点 --> <Additional> <FileName>附加文件名称</FileName> <Position>附加在文档中的位置,一个页面平均划分为9块,排列顺序为从上到下,从左到右,此字段的取值为1~9,分别代表9块区域,附加的内容默认在区域中居中放置</Position> </Additional> ...... </Page> <Page> <Source>原文件名</Source> <Dest>目标文件名,当不合并为一个文档时有效</Dest> <PageNo>顺序,当需要将文档合并为一个PDF文档时,此字段用来设定在文档中所在页号</PageNo> <!-- 如果有多个附加文件,会有多个Additional节点 --> <Additional> <FileName>附加文件名称</FileName> <Position>附加在文档中的位置,一个页面平均划分为9块,排列顺序为从上到下,从左到右,此字段的取值为1~9,分别代表9块区域,附加的内容默认在区域中居中放置</Position> </Additional> ...... </Page> ...... </Root> </xml>
tony4geek 2015-10-19
  • 打赏
  • 举报
回复
public static void main(String args[]) {
		String s = "<?xml version=\"1.0\" encoding=\"UTF-8\"?>";
		s += "<Root>";
		s += "<Merge>true</Merge>";
		s += "<DestName>destName</DestName>";
		s += "<Page>";
		s += "<Source>source1</Source>";
		s += "<Dest>dest1</Dest>";
		s += "<PageNo>1</PageNo>";
		s += "<Additional>";
		s += "<FileName>filename1</FileName>";
		s += "<Position>1</Position>";
		s += "</Additional>";
		s += "<Additional>";
		s += "<FileName>filename2</FileName>";
		s += "<Position>2</Position>";
		s += "</Additional>";
		s += "<Additional>";
		s += "<FileName>filename3</FileName>";
		s += "<Position>3</Position>";
		s += "</Additional>";
		s += "</Page>";
		s += "<Page>";
		s += "<Source>source2</Source>";
		s += "<Dest>dest2</Dest>";
		s += "<PageNo>2</PageNo>";
		s += "<Additional>";
		s += "<FileName>filename2</FileName>";
		s += "<Position>2</Position>";
		s += "</Additional>";
		s += "<Additional>";
		s += "<FileName>filename4</FileName>";
		s += "<Position>4</Position>";
		s += "</Additional>";
		s += "<Additional>";
		s += "<FileName>filename6</FileName>";
		s += "<Position>6</Position>";
		s += "</Additional>";
		s += "</Page>";
		s += "<Page>";
		s += "<Source>source3</Source>";
		s += "<Dest>dest3</Dest>";
		s += "<PageNo>3</PageNo>";
		s += "<Additional>";
		s += "<FileName>filename3</FileName>";
		s += "<Position>3</Position>";
		s += "</Additional>";
		s += "<Additional>";
		s += "<FileName>filename6</FileName>";
		s += "<Position>6</Position>";
		s += "</Additional>";
		s += "<Additional>";
		s += "<FileName>filename9</FileName>";
		s += "<Position>9</Position>";
		s += "</Additional>";
		s += "</Page>";
		s += "</Root>";

		Document doc = Jsoup.parse(s);
		Elements pages = doc.getElementsByTag("Page");
		for (int i = 0; i < pages.size(); i++) {
			System.out.println(doc.getElementsByTag("Source").get(i).text());
			System.out.println(doc.getElementsByTag("Dest").get(i).text());
			System.out.println(doc.getElementsByTag("pageno").get(i).text());

		}
	}
jsoup
心随自在飞 2015-10-19
  • 打赏
  • 举报
回复
每一个Page 标签 的内容 你把它解析成Page对象啊 Page类里面有source , dest ,pageNo , listAdditional 等属性啊

67,550

社区成员

发帖
与我相关
我的任务
社区描述
J2EE只是Java企业应用。我们需要一个跨J2SE/WEB/EJB的微容器,保护我们的业务核心组件(中间件),以延续它的生命力,而不是依赖J2SE/J2EE版本。
社区管理员
  • Java EE
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧