精品文档
XML基础教程 课后习题
习题一
1答 HTML是用来编写Web页的语言、不允许用户自定义标记 HTML体现数据的显示格式。 XML描述数据的组织结构、可自定义标记其标记名称是对标记所包含的数据内容含义的抽象而不是数据的显示格式。
2答使用UTF-8保存
5 答 1不可以 2可以 3不可以
6答 Show.csstime
{ display:block;font-size: 18pt;font-weight:bold
}hour
{ display:line;font-size: 16pt;font-style: italic
}mimute
{ display:line;font-size:9pt;font-weight:bold
}
习题二1答 1使用ANS I编码。 2可以。 3不合理。
2答不相同。
3答 1和2。
4答 A3.xml。
5答 “root”标记包含的文本内容都是空白字符。 “a1”标记包含的文本内容:<CCTV5>。 “a2”标记包含的文本内容:子曰"有朋自远方来,不亦乐乎"。习题三1答一个规范的XML文件如果和某个DTD文件相关联并遵守该DTD文件规定的约束条件就称之为有效的XML文件。
2答 DTD文件的编码必须和其约束的XML文件的编码相一致。
3答无关。
4答 (1)使用SYSTEM文档类型声明的格式
<DOCTYPE根标记的名称SYSTEM "DTD文件的URI">
(2)使用PUBLIC文档类型声明的格式
<!DOCTYPE根标记的名称PUBLIC "正式公用标识符" "DTD文件的URI">
5答一定。
6答 1约束标记“张三”必须有“学号”属性
2约束标记“张三”必须有“学号”属性而且学号的属性值是固定的
220123。
3约束标记“张三”可以有也可以没有“学号”属性。
精品文档
7答 ID类型的属性的属性值具有互斥性 即所有ID类型的属性的属性值必须互不相同。
8答不合理。
9答 1、 3和4。
10答 B.xml不是有效的。将B.xml修改为有效
B.xml
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE 成绩单 SYSTEM "A.dtd">
<成绩单>
<学生>
<姓名>张三</姓名>
<成绩>优秀</成绩>
</学生>
<学生>
<姓名>李四</姓名>
<成绩> 良好</成绩>
</学生>
</成绩单>
习题四
1.答 一个返回子孙节点 而另一个只返回子节点 1 getElementsByTagName(String name) :返回一个NodeList对象该对象由当前节点的Element类型子孙节点组成这些子孙节点的名字由参数name指定
2 getChildNodes() :节点调用该方法返回一个由当前节点的所有子节点
组成的NodeList对象。
2答分别是DocumentType类型和Element类型。
3
JAXPXit i5. javaimport org.w3c.dom.*;import javax.xml.parsers.*;import java. io.*;public class JAXPXiti5
{public static void main(String args[])
{
OutResult outContent=new OutResult() ;try {
DocumentBuilderFactory factory=
DocumentBuilderFactory.newInstance() ;
DocumentBuilder builder= factory.newDocumentBuilder() ;
Document document= builder. parse(newFile("a.xml") ) ;
Element root=document.getDocumentElement() ;
精品文档
String rootName=root.getNodeName() ;
NodeList nodeList=root.getChildNodes() ;outContent.output(nodeList) ;
System.out.println(" 数 学 平 均 成 绩"+outContent.mathAver) ;
System.out.println(" 物 理 平 均 成 绩"+outContent.physicsAver) ;
}catch(Exception e)
{
System.out.println(e) ;
}
}
}class OutResult
{double sumAllMath, sumAllPhysics,mathAver,physicsAver;int mathNumber=0, physicsNumber=0;public void output(NodeList nodeList)
{int size=nodeList.getLength() ;for(int k=0;k<size;k++)
{
Node node=nodeList. item(k) ;if(node.getNodeType()==Node.TEXT_NODE)
{
Text textNode=(Text)node;
String content=textNode.getWholeText() ;
System.out.print(content) ;
Element parent=(Element)textNode.getParentNode() ;if(parent.getNodeName() . equals("数学") )
{mathNumber++;sumAllMath=sumAllMath+Double.parseDouble(content. trim() ) ;
}if(parent.getNodeName() . equals("物理") )
{physicsNumber++;sumAllPhysics=sumAllPhysics+Double.parseDouble(content. trim() ) ;
}
}if(node.getNodeType()==Node.ELEMENT_NODE)
{
Element elementNode=(Element)node;
String name=elementNode.getNodeName() ;
System.out.print(name) ;
NodeList nodes=elementNode.getChildNodes() ;
精品文档output(nodes) ;
}
}mathAver=sumAl lMath/mathNumber;physicsAver=sumAllPhysics/physicsNumber;
}
}
习题五 DOM解析器的核心是在内存中建立和XML文件相对应的树形结构数据如果XML文件较大相应的Document对象就要占用较多的内存空间 SAX解析器不在内存中建立和XML文件相对应的树形结构数据和DOM解析器相比 SAX解析器占有的内存少。
1答不报告。 这个答案不知道
2答 uri和localName的取值是空字符组成的串即ur i="" localName=""参数qName取值是标记名称 atts是标记的所有属性的集合。
3答 当忽略标记之间形成的空白区域时。
4.答 Xiti7. javaimport org.w3c.dom.*;import javax.xml.parsers.*;import java. io.*;public class Xiti7
{public static void main(String args[])
{
OutTotal outWeight=new OutTotal () ;try {
DocumentBuilderFactoryfactory=DocumentBuilderFactory. newInstance() ;
DocumentBuilder builder= factory.newDocumentBuilder() ;
Document document= builder.parse(new
File("a.xml") ) ;
Element root=document.getDocumentElement() ;
NodeList nodeList=root.getChildNodes() ;outWeight.output(nodeList) ;
System.out.println("总重量 "+outWeight. sum) ;
}catch(Exception e) {
System.out.println(e) ;
}
}
}class OutTotal
{double sum;
精品文档public void output(NodeList nodeList)
{int size=nodeList.getLength() ;for(int k=0;k<size;k++)
{
Node node=nodeList. item(k) ;if(node.getNodeType()==Node.TEXT_NODE)
{
Text textNode=(Text)node;
String content=textNode.getWholeText() ;
System.out.print(content) ;
Element parent=(Element)textNode.getParentNode() ;if(parent.getNodeName() . equals("重量") )sum=sum+Double.parseDouble(content. trim() ) ; }if(node.getNodeType()==Node.ELEMENT_NODE)
{
Element elementNode=(Element)node;
String name=elementNode.getNodeName() ;
System.out.print(name) ;
NodeList nodes=elementNode.getChildNodes() ;output(nodes) ;
}
}
}
}
习题六1答 Element类型节点对应XML中的标记。
2答
1按顺序对应着第一个名字是“教室”的标记中的第一个名字是“桌子”标记的“价格”标记。
(2)对应着具有属性number属性值是02、名字为“桌子”的标记而且这些桌子标记有子标记“价格”而且价格包含的文本是数字且值大于等于360。
3对应“教室”的属性。
4 number属性所在的“教室”节点。
5 109
6 396 267
7对应着“教室”标记具教室标记有孙标记“价格”且“价格”标记含有的数字文本的值大于390 即是第2个“教室”标记。
8对应着价格标记且“价格”标记含有的数字文本的值大于396。
3答
1 【结果1】 : A1001定单的总额
2 【结果2】 : 40.0
3 【结果3】 : 4
4 【结果4】 : 100
精品文档
4答
Xiti8. javaimport javax.xml.xpath.*;import org.xml. sax.*;import org.w3c.dom.*;public class Xiti8{public static void main(String args[]) {try{ XPathFactory xPathFactory=XPathFactory.newInstance() ;XPath xPath=xPathFactory.newXPath() ;
InputSource source=new InputSource("Xiti8.xml") ;String countPath="count(/货品列表/货品/重量)";
String sumPath="sum(/货品列表/货品/重量)";
Doublesum=(Double)xPath. evaluate(sumPath, source,XPathConstants.NUMBER) ;double total=sum.doubleValue() ;
System.out.println("总重量:"+total) ;
}catch(Exception exp) {
System.out.println(exp) ;
}
}
}
5答
Student.xml
<?xml version="1.0" encoding="UTF-8" ?>
<学生列表>
<学生学号='72349876' >
<姓名>张三</姓名>
<性别>男</性别>
<年龄> 29 </年龄>
</学生>
<学生学号=' 12345678' >
<姓名>李张林</姓名>
<性别>男</性别>
<年龄> 18 </年龄>
</学生>
<学生学号='000' >
<姓名>张李号</姓名>
<性别>女</性别>
<年龄> 25 </年龄>
</学生>
</学生列表>
精品文档
Aplication. javapublic class Application{public static void main(String args[]) {new StudentConditionWindow() ;
}
}
StudentConditionWindow. javaimport java.awt.*;import javax. swing.*;public class StudentConditionWindow extends JFrame {
JTextField inputName, inputNumber;
JTextArea showResult;
JButton button;
Box baseBox ,boxV1,boxV2;
StudentConditionWindow() {inputName=new JTextField(10) ;inputNumber=new JTextField(10) ;boxV1=Box.createVerticalBox() ;boxV1.add(new Label ("姓名中包含:") ) ;boxV1.add(new Label ("学号中包含") ) ;boxV2=Box.createVerticalBox() ;boxV2.add(inputName) ;boxV2.add(inputNumber) ;baseBox=Box.createHorizontalBox() ;baseBox.add(boxV1) ;baseBox.add(boxV2) ;
JPanel west=new JPanel () ;west.add(baseBox) ;button=new JButton("确定") ;west.add(button) ;add(west,BorderLayout.WEST) ;showResult=new JTextArea(10, 10) ;showResult. setFont(new Font("宋体",Font.PLAIN, 12) ) ;add(new JScrollPane(showResult) ,BorderLayout.CENTER) ;
FindStudentByXPath findStudent; //负责使用XPath查询学生的对象findStudent=new
FindStudentByXPath(inputName, inputNumber, showResult, "student.xml") ;button.addActionListener(findStudent) ;
精品文档setBounds(10, 10,900,300) ;setVisible(true) ;setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE) ;
}
}
FindStudentByXPath. javaimport javax.xml.xpath.*;import org.w3c.dom.*;import javax. swing.*;import java.awt.event.*;import org.xml. sax.*;public class FindStudentByXPath implements ActionListener {
XPathFactory xPathFactory;
XPath xPath;
String positionPath;
InputSource source;
JTextField inputName, inputNumber;
JTextArea showResult;
FindStudentByXPath(JTextField inputName,JTextFieldinputNumber,JTextArea showResult,String fileName) {this. inputName=inputName;thi s. inputNumber=inputNumber;this. showResult=showResult;xPathFactory=XPathFactory.newInstance() ;xPath=xPathFactory.newXPath() ;source=new InputSource(fileName) ;this.positionPath=positionPath;
}public void actionPerformed(ActionEvent e) {showResult. setText(null) ;
String studentName=inputName.getText() . trim() ;
String studentNumber=inputNumber.getText() . trim() ;
String predicates="[contains(姓名, ' "+studentName+"' ) and"+
"contains(@ 学号, ' "+s tudentNumber+"' ) ]";
String path="/学生列表/学生"+predicates+"/*";//XPath路径表达式try{
NodeList nodelist=
(NodeList)xPath.evaluate(path, source,XPathConstants.NODESET) ;int size=nodelist.getLength() ;
精品文档for(int k=0;k<size;k++) {
Node node=nodelist. item(k) ;
String name=node.getNodeName() ;showResult.append(" "+name+":") ;
String content=node.getTextContent() ;showResult.append(content+"\n") ;if(name. startsWith("年龄") )showResult.append("--------------------------\n") ;
}
}catch(Exception exp) {showResult. setText(null) ;showResult.append("异常:"+exp) ;
}
}
}
习题七
1答参考例子2即可完成。
2答参见例子3即可完成。
习题八1答使用操作指令
<?xml-stylesheet href ="样式表的URI" type= "text/css" ?>
2答student
{ display:block;font-size: 18pt; color:red;
}
3答假设XML文件中有三个标记的名称都是“name” “ID”属性分别是a001,a002,a003。 CSS文件如下name a001
{ display:block;border-style:double;width=260;height=120
}name a002
{ display:block;border-style:dotted;width=150;height=60 ;font-size: 10pt;
官方网站:点击访问火数云活动官网活动方案:CPU内存硬盘带宽流量架构IP机房价格购买地址4核4G50G 高效云盘20Mbps独享不限openstack1个九江287元/月立即抢购4核8G50G 高效云盘20Mbps独享不限openstack1个九江329元/月立即抢购2核2G50G 高效云盘5Mbps独享不限openstack1个大连15.9元/月立即抢购2核4G50G 高效云盘5Mbps独享不限...
这不端午节和大家一样回家休息几天,也没有照顾网站的更新。今天又出去忙一天没有时间更新,这里简单搜集看看是不是有一些商家促销活动,因为我看到电商平台各种推送活动今天又开始一波,所以说现在的各种促销让人真的很累。比如在前面我们也有看到PacificRack 商家发布过年中活动,这不在端午节(昨天)又发布一款闪购活动,有些朋友姑且较多是端午节活动,刚才有看到活动还在的,如果有需要的朋友可以看看。第一、端...
profitserver正在对德国vps(法兰克福)、西班牙vps(马德里)、荷兰vps(杜廷赫姆)这3处数据中心内的VPS进行5折优惠促销。所有VPS基于KVM虚拟,纯SSD阵列,自带一个IPv4,不限制流量,在后台支持自定义ISO文件,方便大家折腾!此外还有以下数据中心:俄罗斯(多机房)、捷克、保加利亚、立陶宛、新加坡、美国(洛杉矶、锡考克斯、迈阿密)、瑞士、波兰、乌克兰,VPS和前面的一样性...