编写一个Java程序,使用DOM解析器解析下列XML文件
要求输出各个标记的名字以及标记中的数据,并计算出“数学”和“物理”的平均成绩Xiti5.xml<?xmlversion="1.0"encoding="UTF-8"?><成...
要求输出各个标记的名字以及标记中的数据,并计算出“数学”和“物理”的平均成绩
Xiti5.xml
<?xml version="1.0" encoding="UTF-8" ?>
<成绩单>
<张三>
<数学>89</数学>
<物理>78</物理>
</张三>
<李四>
<数学>67</数学>
<物理>80</物理>
</李四>
</成绩单>
请看清题目,要完整代码 展开
Xiti5.xml
<?xml version="1.0" encoding="UTF-8" ?>
<成绩单>
<张三>
<数学>89</数学>
<物理>78</物理>
</张三>
<李四>
<数学>67</数学>
<物理>80</物理>
</李四>
</成绩单>
请看清题目,要完整代码 展开
3个回答
展开全部
用dom4j解析,非常快,具体怎么解析
SAXReader reader = new SAXReader();
String filePath = "c:/abc.xml";
File file = new File(filePath);
Document document = reader.read(file);// 读取XML文件
Element root = document.getRootElement();// 得到根节点
Element select = root.element("select");
for (Iterator i = select.nodeIterator(); i.hasNext();) {
Object obj = i.next();
String content = "";
if (obj instanceof Text) {
content = ((Text)obj).getText().replaceAll("\n", "").trim();
SAXReader reader = new SAXReader();
String filePath = "c:/abc.xml";
File file = new File(filePath);
Document document = reader.read(file);// 读取XML文件
Element root = document.getRootElement();// 得到根节点
Element select = root.element("select");
for (Iterator i = select.nodeIterator(); i.hasNext();) {
Object obj = i.next();
String content = "";
if (obj instanceof Text) {
content = ((Text)obj).getText().replaceAll("\n", "").trim();
展开全部
import javax.xml.parsers.*;
import org.w3c.dom.*;
public class Test2 {
public static void main(String args[ ]){
try{
DocumentBuilderFactory factory = DocumentBuilderFactory.newInstance();
DocumentBuilder builder=factory.newDocumentBuilder();
Document doc=builder.parse("c.xml");
Element root =doc.getDocumentElement();
NodeList list =root.getChildNodes();
double summ=0,sump=0;
int count=0;
double avgm=0,avgp=0;
for(int i=0;i<list.getLength();i++){
Node node=list.item(i);
if(node.getNodeType()==Node.ELEMENT_NODE){
count++;
NodeList tlist= (( Element)node).getElementsByTagName("数学");
summ=summ+Double.parseDouble(tlist.item(0).getFirstChild().getNodeValue());
NodeList tlist1= (( Element)node).getElementsByTagName("物理");
sump=sump+Double.parseDouble(tlist1.item(0).getFirstChild().getNodeValue());
}else{
System.out.println(node.getNodeType());
}
}
avgm=summ/(count*1.0);
avgp=sump/(count*1.0);
System.out.println(avgm+"|"+avgp);
}catch(Exception e){e.printStackTrace();}
}
}
结束
import org.w3c.dom.*;
public class Test2 {
public static void main(String args[ ]){
try{
DocumentBuilderFactory factory = DocumentBuilderFactory.newInstance();
DocumentBuilder builder=factory.newDocumentBuilder();
Document doc=builder.parse("c.xml");
Element root =doc.getDocumentElement();
NodeList list =root.getChildNodes();
double summ=0,sump=0;
int count=0;
double avgm=0,avgp=0;
for(int i=0;i<list.getLength();i++){
Node node=list.item(i);
if(node.getNodeType()==Node.ELEMENT_NODE){
count++;
NodeList tlist= (( Element)node).getElementsByTagName("数学");
summ=summ+Double.parseDouble(tlist.item(0).getFirstChild().getNodeValue());
NodeList tlist1= (( Element)node).getElementsByTagName("物理");
sump=sump+Double.parseDouble(tlist1.item(0).getFirstChild().getNodeValue());
}else{
System.out.println(node.getNodeType());
}
}
avgm=summ/(count*1.0);
avgp=sump/(count*1.0);
System.out.println(avgm+"|"+avgp);
}catch(Exception e){e.printStackTrace();}
}
}
结束
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
既然有了答案就不贴代码了,我只想说着XML格式设计的不是一般的坑爹。
<scores>
<student name="张三">
<class name="数学">89</class>
<class name="物理">78</class>
</student>
<student name="李四">
<class></class>
<class></class>
</student>
</scores>
<scores>
<student name="张三">
<class name="数学">89</class>
<class name="物理">78</class>
</student>
<student name="李四">
<class></class>
<class></class>
</student>
</scores>
本回答被提问者和网友采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询