标记xml基础教程课后习题解答

xml教程  时间:2021-03-15  阅读:()

精品文档

XML基础教程 课后习题

习题一

1答 HTML是用来编写Web页的语言、不允许用户自定义标记 HTML体现数据的显示格式。 XML描述数据的组织结构、可自定义标记其标记名称是对标记所包含的数据内容含义的抽象而不是数据的显示格式。

2答使用UTF-8保存

5 答 1不可以 2可以 3不可以

6答 Show.csstime

{ 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;

云雀云(larkyun)低至368元/月,广州移动1Gbps带宽VDS(带100G防御),常州联通1Gbps带宽VDS

云雀云(larkyun)当前主要运作国内线路的机器,最大提供1Gbps服务器,有云服务器(VDS)、也有独立服务器,对接国内、国外的效果都是相当靠谱的。此外,还有台湾hinet线路的动态云服务器和静态云服务器。当前,larkyun对广州移动二期正在搞优惠促销!官方网站:https://larkyun.top付款方式:支付宝、微信、USDT广移二期开售8折折扣码:56NZVE0YZN (试用于常州联...

VPSDime7美元/月,美国达拉斯Windows VPS,2核4G/50GB SSD/2TB流量/Hyper-V虚拟化

VPSDime是2013年成立的国外VPS主机商,以大内存闻名业界,主营基于OpenVZ和KVM虚拟化的Linux套餐,大内存、10Gbps大带宽、大硬盘,有美国西雅图、达拉斯、新泽西、英国、荷兰机房可选。在上个月搞了一款达拉斯Linux系统VPS促销,详情查看:VPSDime夏季促销:美国达拉斯VPS/2G内存/2核/20gSSD/1T流量/$20/年,此次推出一款Windows VPS,依然是...

CloudCone闪购优惠洛杉矶MC机房VPS月$1.99 便宜可随意删除重开

CloudCone商家我们很多喜欢低价便宜VPS主机的肯定是熟悉的,个人不是特别喜欢他。因为我之前测试过几次,开通的机器IP都是不通的,需要删除且开通好几次才能得到一个可用的IP地址。当然他们家的优势也是有的,就是价格确实便宜,而且还支持删除重新开通,而且机房只有一个洛杉矶MC。实话,如果他们家能多几个机房,保持现在的特点,还是有很多市场的。CloudCone是来自美国的主机销售商,成立于2017...

xml教程为你推荐
Baby被问婚变绯闻小s在黄晓明婚礼上问了什么问题access数据库access数据库的组成是什么lunwenjiancepaperfree论文检测怎样算合格杰景新特杰德特这个英雄怎么样seo优化工具SEO优化神器有什么比较好的?m.kan84.net那里有免费的电影看?avtt4.comCOM1/COM3/COM4是什么意思??/m88.comm88.com现在的官方网址是哪个啊 ?m88.com分析软件?kb123.net连网方式:wap和net到底有什么不一样的www.03024.comwww.sohu.com是什么
上海服务器租用 net主机 themeforest nerd iis安装教程 lighttpd 中国电信测速112 什么是服务器托管 国外免费asp空间 免费ftp cxz 独立主机 云服务器比较 阿里云邮箱个人版 北京主机托管 register.com phpwind论坛 建站论坛 webmin winserver2008下载 更多