Java利用JDom解析和传递XML格式数据
Java利用JDom来解析处理XML数据格式:
需要的包jdom-1.1.2.jar
1 将数据转换成XML格式的数据进行传递
Element rootList, firstList, secondItem, thirdItem;
//根元素标签名
rootList = new Element("root");
//根元素标签内的属性名与值
rootList.setAttribute("project", pname);
//生成Doc文档
Document Doc = new Document(rootList);
//获取文档中的根标签
rootList = Doc.getRootElement();
for (int i = 0; i < judges.size(); i++)
{
//生成新的元素
firstList = new Element("flayout");
firstList.setAttribute("percent", "percent");
//加入根级元素中
rootList.addContent(firstList);
}
XMLOutputter XMLOut = new XMLOutputter();
//将doc文档转换为字符串型的XML格式
String xmlinfo = XMLOut.outputString(Doc);
//将开头的去掉
xmlinfo = xmlinfo.replace("<?xml version=\"1.0\" encoding=\"UTF-8\"?>",
"");
//返回已经封装好的XML数据
return xmlinfo;
2 将字符串中的XML解析出进行处理
//创建一个新的字符串
StringReader read = new StringReader(stadXML);
// 创建新的输入源SAX 解析器将使用 InputSource 对象来确定如何读取 XML 输入
InputSource source = new InputSource(read);
// 创建一个新的SAXBuilder
SAXBuilder sb = new SAXBuilder();
String projectName;
List<Judgestandard> standIndex = new ArrayList<Judgestandard>();
try {
// 通过输入源构造一个Document
Document doc = sb.build(source);
// 取的根元素
Element root = doc.getRootElement();
projectName = root.getAttributeValue("project");
// 得到根元素所有子元素的集合
Element et = null;
List nodes = root.getChildren();
// 第一级指标
for (int i = 0; i < nodes.size(); i++) {
et = (Element) nodes.get(i);// 循环依次得到子元素
Judgestandard judge = new Judgestandard();
//获取该元素中属性的值
String fid = et.getAttributeValue("mainid");
//获取元素的孩子数目
List fsize = et.getChildren();
// 第二级指标
for (int j = 0; j < fsize.size(); j++)
{
et = (Element) fsize.get(j);// 循环依次得到子元素
et.getAttributeValue("stdid")
}
Java处理XML文档
原始XML:
<?xml version="1.0" encoding="UTF-8"?> <HD> <disk name="C"> <capacity>8G</capacity> <files>1580</files> </disk> <disk name="D"> <capacity>10G</capacity> <files>3000</files> </disk> </HD>
Java处理代码:
import java.util.List;
import org.jdom.Document;
import org.jdom.Element;
import org.jdom.input.SAXBuilder;
/**
* <?xml version="1.0" encoding="UTF-8"?>
*<HD>
* <disk name="C">
* <capacity>8G</capacity>
* <files>1580</files>
* </disk>
* <disk name="D">
* <capacity>10G</capacity>
* <files>3000</files>
* </disk>
*</HD>
* @author Administrator
*
*/
//利用JDom来解析XML文件
public class JDomParseXMLFile {
public static void main(String[] args) throws Exception{
SAXBuilder sb=new SAXBuilder();
//下面两种构建document的方式,将xml和该解析类都放在默认包下
Document doc=sb.build(JDomParseXMLFile.class.getClassLoader().getResourceAsStream("test.xml"));
//Document doc=sb.build("src/test.xml");//构造文档对象
Document doc=sb.build("src/test.xml");//构造文档对象
Element root=doc.getRootElement();//获取根元素,即文档中的<HD>
List list=root.getChildren("disk");//取名字为disk的所有元素
for(int i=0;i<list.size();i++)
{
Element element=(Element)list.get(i);//依此遍历所有的disk节点
String name=element.getAttributeValue("name");
String capacity=element.getChildText("capacity");//取disk子元素capacity的内容
String files=element.getChildText("files");
System.out.println("name:"+name);
System.out.println("capacity"+capacity);
System.out.println("files"+files);
}
}
}
转载于:https://blog.51cto.com/computerdragon/1121518