时间: 2016/02/17

目标:为telenor的ALU Femto接口写一个采集xml文件并解析出locationName标签里的值,然后更新到数据库中。

从网上搜了下,有四种常用的解析xml的方式,包括DOM,JAXD,Dom4J,SAX(simple api for xml).我正好有Dom4j的jar包,就选择了Dom4j来解析xml。

前半截对xml的解析测试成功了。后面的数据库的连接,把数据更新到数据库的操作没有测试。对应的xml文件的行数有点多,没法上传,另写一个xml的文档上传。

 package com.example.xml.dom4h;

 import java.io.File;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.Statement;
import java.util.Iterator;
import java.util.List; import javax.xml.parsers.DocumentBuilder;
import javax.xml.parsers.DocumentBuilderFactory; import org.dom4j.Document;
import org.dom4j.Element;
import org.dom4j.io.DOMReader;
import org.dom4j.io.SAXReader; /**
* dom4j框架学习: 读取并解析xml
*
*
*/
public class Dom4j_parse {
public static void main(String[] args) throws Exception {
SAXReader saxReader = new SAXReader(); Document document = saxReader.read(new File("snapshot-Automatic-2016-02-09-15-53-00-1.xml"));
String bsrName = "";
String bsrId = "";
String region = "";
String city = "";
String address ="";
String classification = "";
// 获取根元素
Element root = document.getRootElement();
System.out.println("Root: " + root.getName()); // 获取所有子元素
List<Element> childList = root.elements();
System.out.println("total child count: " + childList.size()); // 获取特定名称的子元素
Element femtoCluster = root.element("FemtoCluster");
List<Element> childList2 = femtoCluster.elements("Femto"); System.out.println("locationname child: " + childList2.size());
//对每一个femto的locationName解析
for(int i=0; i < childList2.size(); i++){
Element femtoElement = childList2.get(i);
String femtoId= femtoElement.attributeValue("id");
Element attributeElement = femtoElement.element("attributes"); //step1 对bsc的名称和id先处理 Element bsrNameElement = attributeElement.element("bSRName");
Element bsridElement = attributeElement.element("bsrId");
bsrName = bsrNameElement.getTextTrim();
bsrId = bsridElement.getTextTrim();
System.out.println( " bstname :"+bsrNameElement.getTextTrim()+ " ,bsrid :"+bsridElement.getTextTrim());
//step2 对locatin的处理
//用下划线把值分割成三部分,第一部分是region,第二部分是address,第三部分是city
Element locationElement = attributeElement.element("locationName");
String allString = locationElement.getTextTrim();
//如果有值,安装上面的三部分解析,如果没值,给region,city为空。
if(!allString.isEmpty() && allString !=null && allString !="" ){
//allString有值的时候
String[] allStringArray = allString.split("_");
region = allStringArray[0];
city = allStringArray[2];
address = allStringArray[1];
if(city.isEmpty() ){
classification = "RR";
}else{
classification = "U_SB";
}
System.out.println( " region :"+ region + " , city :"+city +" , address:"+ address);
}else{
//allString没有值得时候
region = "";
city = "";
address = "";
classification = "RR";
System.out.println( " region :"+ region + " , city :"+city +" , address:"+ address);
}//end if
//对这些数据插入到数据库中
/*
* update pm4h_db.mo_moentity t set (region,city,address,classification) = (region,city,address,classification)
* where t.moentityid = bsrId
*
* */
}// end one element
// 获取名字为指定名称的第一个子元素
// Element firstWorldElement = root.element("world");
// // 输出其属性
// System.out.println("first World Attr: "
// + firstWorldElement.attribute(0).getName() + "="
// + firstWorldElement.attributeValue("name"));
//
// System.out.println("迭代输出-----------------------");
// // 迭代输出
// for (Iterator iter = root.elementIterator(); iter.hasNext();) {
// Element e = (Element) iter.next();
// System.out.println(e.attributeValue("name"));
//
// } // System.out.println("用DOMReader-----------------------");
// DocumentBuilderFactory dbf = DocumentBuilderFactory.newInstance();
// DocumentBuilder db = dbf.newDocumentBuilder();
// // 注意要用完整类名
// org.w3c.dom.Document document2 = db.parse(new File("students.xml "));
//
// DOMReader domReader = new DOMReader();
//
// // 将JAXP的Document转换为dom4j的Document
// Document document3 = domReader.read(document2);
//
// Element rootElement = document3.getRootElement();
//
// System.out.println("Root: " + rootElement.getName());
//连接数据库,并执行更新sql的方法 } public void updateFemtoData(String region1,String city1,String address1,String classification1,String bsrid1) {
try{
//0 拼sql语句 //modify
String sql= " update pm4h_db.mo_moentity t set t.region =" + region1
+" ,city = "+ city1
+" , classification= "+ classification1
+" ,address = "+ address1
+ " where t.moentityid = " +bsrid1
;
//1.加载驱动
Class.forName("oracle.jdbc.driver.OracleDriver");
//2 建立连接
//modify ip and
Connection ct = DriverManager.getConnection("jdbc:oracle:thin:@10.218.6.165:1521:mos5200","oracle","oracle");
Statement st = ct.createStatement() ;
int rs = st.executeUpdate(sql);
}catch(Exception e){
e.printStackTrace();
}finally{ if(true){
// st.close();
// ct.close();
}
}

java代码用dom4j解析xml文件的简单操作的更多相关文章

  1. java中采用dom4j解析xml文件

    一.前言 在最近的开发中用到了dom4j来解析xml文件,以前听说过来解析xml文件的几种标准方式:但是从来的没有应用过来,所以可以在google中搜索dmo4j解析xml文件的方式,学习一下dom4 ...

  2. java中利用dom4j解析XML文件

    官网下载Dom4j地址:https://dom4j.github.io/ 注意:使用Dom4j开发,需下载dom4j相应的jar文件 题目:后台利用dom4j解析student.xml文件,并返回Li ...

  3. 【JAVA使用XPath、DOM4J解析XML文件,实现对XML文件的CRUD操作】

    一.简介 1.使用XPath可以快速精确定位指定的节点,以实现对XML文件的CRUD操作. 2.去网上下载一个“XPath帮助文档”,以便于查看语法等详细信息,最好是那种有很多实例的那种. 3.学习X ...

  4. java使用dom4j解析xml文件

    关于xml的知识,及作用什么的就不说了,直接解释如何使用dom4j解析.假如有如下xml: dom4j解析xml其实很简单,只要你有点java基础,知道xml文件.结合下面的xml文件和java代码, ...

  5. Java进阶(二十七)使用Dom4j解析XML文件

    使用Dom4j解析XML文件 写在前面的话 由于论文实验要求,需要实现操作XML文档,为此想到了dom4j这个工具,使用之后深感受益.在此分享给大家,以此共勉. 注:本文转载自http://blog. ...

  6. 【java项目实战】dom4j解析xml文件,连接Oracle数据库

    简单介绍 dom4j是由dom4j.org出品的一个开源XML解析包.这句话太官方.我们还是看一下官方给出的解释.例如以下图: dom4j是一个易于使用的.开源的,用于解析XML,XPath和XSLT ...

  7. 转:在java中使用dom4j解析xml

    JAVA 使用Dom4j 解析XML Java DOM4J Parser - Parse XML Document Dom4j下载及使用Dom4j读写XML简介 在java中使用dom4j解析xml ...

  8. 用DOM4J解析XML文件案例

    用DOM4J解析XML文件案例,由于DOM4J不像JAXP属于JAVASE里,所以如果要使用DOM4J,则必须额外引入jar包,如图:

  9. Dom4j解析Xml文件,Dom4j创建Xml文件

    Dom4j解析Xml文件,Dom4j创建Xml文件 >>>>>>>>>>>>>>>>>>&g ...

随机推荐

  1. 游戏Demo(持续更新中...)

    格斗游戏 主要用于联系Unity的动画系统,并加入了通过检测按键触发不同的技能. WASD控制方向,AD为技能1,SW为技能2,右键跳跃,连续单机普通连招. 本来是要用遮罩实现跑动过程中的攻击动作,但 ...

  2. LeetCode OJ 120. Triangle

    Given a triangle, find the minimum path sum from top to bottom. Each step you may move to adjacent n ...

  3. CodeForces 697B Barnicle 模拟

    强行模拟 纪念一下…… #include<stdio.h> #include<iostream> #include<algorithm> #include<m ...

  4. 2016NEFU集训第n+5场 A - Chinese Girls' Amusement

    Description       You must have heard that the Chinese culture is quite different from that of Europ ...

  5. 对象比较中 "相等性"和"同一性" 生动地解释

    对象们都住在不同的房间里,每个房间只能住一个对象.对象们都被锁在房间里,永远没有办法搬家(至少从我们讨论的角度来说,这个说法是正确的).所以如果你知道了一个对象的房间号,就能找到对应的对象. 现在假如 ...

  6. Openjudge-计算概论(A)-奥运奖牌计数

    描述: 2008年北京奥运会,A国的运动员参与了n天的决赛项目(1≤n≤17).现在要统计一下A国所获得的金.银.铜牌数目及总奖牌数. 输入输入n+1行,第1行是A国参与决赛项目的天数n,其后n行,每 ...

  7. 设n是奇数,证明:16|(n4+4n2+11)(整除原理1.1.1)

    设n是奇数,证明:16|(n4+4n2+11) 解: 令n=2k+1,k∈z n4+4n2+11 =(2k+1)4+4(2k+1)2+11 =(4k2+4k+1)2+(2k+1)2+11 =16k4+ ...

  8. Core Animation中的组动画

    实际开发中一个物体的运动往往是复合运动,单一属性的运动情况比较少,但恰恰属性动画每次进行动画设置时一次只能设置一个属性进行动画控制(不管是 基础动画还是关键帧动画都是如此),这样一来要做一个复合运动的 ...

  9. mongoDB5--mongoDB增删改查

    之前我们探讨了mongodb的"增删改查",要知道,我们的增删改其实都离不开查询表达式,所以查询表达式在mongodb是非常重要的.关于查询其实我们只是介绍了以小部分.关于mong ...

  10. mysql基本操作 [http://www.cnblogs.com/ggjucheng/archive/2012/11/03/2752082.html]

    创建表 简单的方式 CREATE TABLE person ( number INT(11), name VARCHAR(255), birthday DATE ); 或者是 CREATE TABLE ...