ubuntu10.04安装配置指南_第1页
ubuntu10.04安装配置指南_第2页
ubuntu10.04安装配置指南_第3页
ubuntu10.04安装配置指南_第4页
ubuntu10.04安装配置指南_第5页
已阅读5页,还剩72页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、Ubuntu 10.04 安装配置指南作者: HYPERLINK http:/jandy.me/ o Jandy Jandy版本:1004.1.0504目录、 HYPERLINK /View?id=dgthtrjr_345hq4t4dgk l prepare t _self o 准备 准备一、 HYPERLINK /View?id=dgthtrjr_345hq4t4dgk l install t _self o 安装 安装二、 HYPERLINK /View?id=dgthtrjr_345hq4t4dgk l setting t _self o 配置 配置三、 HYPERLINK /View?

2、id=dgthtrjr_345hq4t4dgk l pinyin t _self o 输入法 输入法四、 HYPERLINK /View?id=dgthtrjr_345hq4t4dgk l flash t _self o Flash Flash五、 HYPERLINK /View?id=dgthtrjr_345hq4t4dgk l others t _self o 附录 附录六、 HYPERLINK /View?id=dgthtrjr_345hq4t4dgk l update t _self o 更新 更新、准备1、下载Ubuntu光盘镜像文件: HYPERLINK /123/?p=79 o

3、/123/?p=79 /123/?p=792、校验Ubuntu光盘镜像文件的MD5: HYPERLINK /123/?p=85 o /123/?p=85 /123/?p=853、备份数据: HYPERLINK /123/?p=92 o /123/?p=92 /123/?p=924、用U盘制作Live USB: HYPERLINK /123/?p=18 o /123/?p=18 /123/?p=18或者把.iso文件刻录到光盘: HYPERLINK /123/?p=56 o /123/?p=56 /123/?p=565、规划分区1)双系统:如果你的电脑里已经装有一个Windows系统,而且硬盘有

4、两个以上的分区的话。你需要把其中一个10GB以上的分区删除掉(最好是删除最后一个分区),以空出一部分未分区的硬盘空间用来安装Ubuntu。这样安装Ubuntu后,系统会自动建立一个启动菜单,让你在开机时选择启动Windows还是Ubuntu。在Windows里删除分区的方法是:a)把要删除的分区中的所有文件移到别的分区。b)右键单击“我的电脑”,选择“管理磁盘管理”。或“控制面板管理工具双击计算机管理存储磁盘管理”。c)右键单击要删除的分区,选择“删除逻辑驱动器”。双系统的分区大小:swap交换空间:物理内存小于或等于2GB,交换空间为物理内存大小的2倍;物理内存大于2GB的,交换空间等于物理

5、内存大小。/ 分区:空闲空间总容量-交换空间。2)单系统:如果你决定在电脑里只安装Ubuntu一个操作系统的话,建议你分3个区:/ 分区:8-30G(一般15G就够了);swap交换空间:物理内存小于或等于2GB,交换空间为物理内存大小的2倍;物理内存大于2GB的,交换空间等于物理内存大小;/home:所有剩余空间。6、网络连接。在Ubuntu里拨号上网比较麻烦,如果你是用ADSL宽带上网,又没有路由器的话,建议你花一百多块钱买个无线路由器,然后在路由器里设置自动拨号,路由器的使用手册里有设置自动拨号的详细说明。如果你是通过其他方式来连接网络的话,请自行Google连接方法(可参考: HYPE

6、RLINK /index.php?title=UbuntuHelp:InternetHowto/zh&variant=zh-cn o /index.php?title=UbuntuHelp:InternetHowto/zh&variant=zh-cn /index.php?title=UbuntuHelp:InternetHowto/zh&variant=zh-cn)。如果你的网速比较慢,或没有网络的话,建议使用Linux Deepin等中文定制版来安装,否则安装后会没有中文输入法,也不能播放常见的影音文件。一、安装1、Ubuntu 10.04的CD镜像里依然没有包含完整的中文语言包和输入法,

7、如果在联网状态下安装的话,安装程序会自动下载语言支持文件,而且2M的ADSL网速下只要几分钟即可下载完毕,所以建议在联网状态下进行安装。在安装前先打开ADSL的Model和路由器,然后用光盘或Live USB启动电脑。技巧:开机时猛按F12、F9等功能键可以选择启动设备,具体是哪个键请翻阅电脑说明书,或开机时注意看屏幕下面的提示。把左边的滚动条拉到底,选择“中文(简体)”,点击“试用Ubuntu 10.04 LTS”。如果你是用Live USB启动的话,就不会有上面的画面,在启动菜单选择“Default”直接进入桌面。如果你是用网线联网的话,应该已经自动联好网络,打开Firefox就直接就可以

8、上网了。如果你是用无线网卡的话,请点击小喇叭左边的网络管理器图标,图标有个红色的叹号表示尚未联网。选择一个可用的无线网络。按提示输入无线网络的密码后,很快就可联上网络,这时网络管理器的图标就没有红色的叹号了。然后双击桌面的“安装 Ubuntu 10.04 LTS”图标进行安装。语言选择:中文(简体)。如果你喜欢用其他语言的话,就自己看着办吧。地区选择:默认是“中国(重庆)”,不知为什么。我在上海,所以就选“中国(上海)”。键盘布局:就用系统建议的“USA”吧。准备硬盘空间:选“手动指定分区(高级)”。如果是在一块全新的硬盘上安装的话,要先“新建分区表”。已经进行过分区的硬盘则可以跳过这步。新建

9、分区表会擦除硬盘上的所有数据!如果你的硬盘不是全新的硬盘的话,就不用新建分区表了,直接选择“空闲”的空间,再点“添加”按钮。先创建 / 分区:“新分区的类型”选择“主分区”;“新分区的位置”保留默认的“起始”;“用于”“Ext4 日志文件系统”;“挂载点”选择“/”。再选择“空闲”空间,点击“添加”按钮。接着创建swap交换空间:“新分区的类型”选“逻辑分区”;“新分区的位置”保留默认的“起始”;“用于”“交换空间”;“挂载点”不用选。如果是双系统的话,分一个 / 加 一个交换空间 就可以了。单系统还可以再分一个 /home,挂载点选“/home”就行了,用“Ext4 日志文件系统”。可以参考

10、9.10版的安装指南: HYPERLINK /fileview?id=0B7vaQCSPJU8PNjUzZmU1ZTItYTVlNi00ZDBmLWFhMzMtN2Q3NDA4MzljMjRm&hl=zh_CN o /fileview?id=0B7vaQCSPJU8PNjUzZmU1ZTItYTVlNi00ZDBmLWFhMzMtN2Q3NDA4MzljMjRm&hl=zh_CN /fileview?id=0B7vaQCSPJU8PNjUzZmU1ZTItYTVlNi00ZDBmLWFhMzMtN2Q3NDA4MzljMjRm&hl=zh_CN填写个人资料:“您的名字”可以使用除冒号(:)和逗

11、号(,)以外的任意字符,中间可以有空格。安装后还可以再修改。“登录名”是开机登录时要输入的用户名,安装后不能再修改。只可以使用英文字母、数字、减号(-)和下划线(_),中间不可以有空格,第一个字符必须是英文字母。注意区分字母的大小写,建议全用小写字母。密码最少要8位,而且不要全是数字或字母,要字母和数字混合。拿出纸和笔,记下你设置的登录名和密码!注意分清登录名和密码使用的字母的大小写。以免忘记。如果你对“登录时需要密码并且加密我的主目录”这个选项不熟悉的话,建议不要选择它,以免加密后连自己都无法访问自己的主目录。填写完毕,点“前进”按钮。检查一下,没问题的话就点击“安装”按钮开始安装。安装需要

12、10-15分钟时间,如果屏幕变黑,那可能是因为键盘和鼠标长时间没动作而启动的屏幕保护,动动鼠标就恢复了,不要紧张,更不要强行关机。Retrieving file 时,如果很慢的话,可以点“跳过”按钮。下载语言包如果很慢的话,也可以先跳过,等安装完成后再换源下载。安装完毕,重启电脑。这行英文的意思是:请取出光盘(Live USB),关上光驱托盘,按回车键(Enter)。如果你是联网安装的话,安装完毕应该就是中文界面了。如果你是断网安装,或者在下载语言包时选择了跳过,重启后会提示你“不完整的语言支持”,这时先不要运行,点击“Close”按钮关闭提示。二、配置如果你刚装好的Ubuntu没有中文界面、

13、没有中文输入法、不能播放常见的影音文件请先不要埋怨,这是因为Ubuntu的公司目前的人力财力有限,暂时还不能为每个国家地区发行一个独立的版本,我们可以自己进行配置。 HYPERLINK /ailurus/?page_id=104 o Ailurus Ailurus这个小程序可以帮助我们更简便地完成对Ubuntu的配置。先下载Ailurus的安装包,下载地址: HYPERLINK /ailurus/ppa/ubuntu/pool/main/a/ailurus/ o /ailurus/ppa/ubuntu/pool/main/a/ailurus/ /ailurus/ppa/ubuntu/pool/

14、main/a/ailurus/我们需要下载扩展名为“.deb”的文件,注意选对版本,比如Ubuntu 10.04的代号是Lucid,就下载“ailurus_10.04.2-0lucid1_all.deb”。下载完毕,双击deb文件,点击“Install Package”按钮开始安装。输入密码。安装完毕,点击“Close”按钮关闭窗口。在系统工具菜单里打开Ailurus。点击“快速安装热门软件”按钮。选择要配置的项目,但这里安装的浏览器Flash插件不是Adobe的官方插件,安装后也不能播放Google音乐和亦歌,浏览网页时仍会提示“您需要其他插件以显示此页面的所有媒体”。你可以选择不安装这里的

15、“浏览器的Flash插件”,稍后再手动安装官方的Flash插件。选好后,点“OK”按钮。输入密码。开始下载所需的软件包。期间可能还会再要输入一到两次密码,请留意提示。配置完毕,如果你电脑的显卡是集成显卡的话,一般会提示“这个系统上没有使用专有驱动”,这表示Ubuntu系统已经自带显卡驱动了,不需要额外安装驱动。点击“关闭”按钮即可。再关闭Ailurus的速配窗口。你还可以用Ailurus来进行其他一些实用的设置,如:1)如果你不喜欢在桌面“显示已经挂载的卷的图标”的话,可以在“系统设置桌面”里取消显示。2)如果你不习惯“最小化”、“最大化”、“关闭”等按钮放在窗口标题栏左边的话,可以在“系统设

16、置窗口效果”里把“窗口标题栏的按钮的布局”设置回“GNOME经典”。3)如果你不喜欢“当屏幕保护程序激活时锁定屏幕”的话,可以在“系统设置GNOME会话”中取消。4)“安装软件Nautilus右键菜单”,添加“以管理员身份打开”项。(稍后我们要用到这个功能。)配置完毕,点击右上角的关闭按钮,选择“Log Out”(注销)或“Restart”(重新启动)。三、输入法重启电脑后,界面就变成中文的了。但还没有拼音输入法,还需要再设置一下。如果你是联网安装在安装过程中自动下载语言包的话,可能不需要这一步,安装完毕直接就有拼音输入法了。左键点击键盘模样的输入法图标,选择“首选项”。点击“输入法选择输入法

17、”。选择“汉语Pinyin”。点击“添加”按钮。选择“汉语 - Pinyin”,点击“向上”按钮,把“汉语 - Pinyin”移动到最上面。关闭IBus首选项窗口。然后就可以选择Pinyin输入法输入汉字了。IBus的候选词排列方向默认是竖直的,你可以在首选项里设置为水平排列。Pinyin输入法的候选词每排只有5个候选词,你可以点击输入法状态条的“i”按钮,把“Number of candidates”拖到9个。四、Flash1)为Firefox浏览器安装Adobe Flash PlayerFirefox默认没有安装Flash Player的插件,打开有Flash的网页时会弹出提示:“您需要其

18、他插件以显示此页面的所有媒体”,点击“安装缺失插件”进行安装时,会安装失败,需要手动安装,方法如下:打开网页 HYPERLINK /flashplayer/ o /flashplayer/ /flashplayer/,点击“Select version to download.”,选择“.deb for Ubuntu 8.04+”,然后点“Agree and Install now”按钮,下载.deb包并保存到桌面或其他文件夹,下载完成后,先关闭所有浏览器窗口,再双击.deb文件进行安装。安装完毕,关闭浏览器重新打开,就可以显示Flash了。2)Flash中文字体显示为方块的解决办法某些软件或

19、网站(如谷歌音乐)的中文字体会显示为方块,进行如下设置即可解决:点击屏幕左上角的菜单“位置主文件夹”,点击左边的“文件系统”,用鼠标右键点击文件夹“etc”选择“以管理员身份打开”,然后再打开文件夹“/fonts/conf.d/”,右键单击文件 49-sansserif.conf 并选择“打开方式Gedit”,把倒数第4行的“sans-serif”改为“sans serif”,保存后关闭文件,重新打开网站,就可以正常显示了。五、附录Ubuntu常用软件 HYPERLINK /123/?p=80 o /123/?p=80 /123/?p=80Ubuntu/Windows常用软件/应用程序对照表

20、HYPERLINK /123/?p=89 o /123/?p=89 /123/?p=89六、更新附录资料:不需要的可以自行删除 libxml2应用实例Libxml2 是一个xml的c语言版的解析器,本来是为Gnome项目开发的工具,是一个基于MIT License的免费开源软件。它除了支持c语言版以外,还支持c+、PHP、Pascal、Ruby、Tcl等语言的绑定,能在Windows、Linux、Solaris、MacOsX等平台上运行。功能还是相当强大的,相信满足一般用户需求没有任何问题。二、 Libxml2安装:一般如果在安装系统的时候选中了所有开发库和开发工具的话(Fedora Core

21、系列下),应该不用安装,下面介绍一下手动安装: 1) 从xmlsoft站点或ftp()站点下载libxml压缩包(libxml2-xxxx.tar.gz)2) 对压缩包进行解压缩 tar xvzf libxml2-xxxx.tar.gz3) 进入解压缩后的文件夹中运行 ./configure -prefix /home/user/myxml/xmlinst(此处为待安装的路径)或者直接使用 ./configure make make install 4) 添加路径 export PATH=/home/user/myxml/xmlinst/bin:$PATH 说明:为了结构清晰,最好将libxm

22、l2不安装在解压目录中。安装完成后就可以使用简单的代码解析XML文件,包括本地和远程的文件,但是在编码上有一些问题。Libxml默认只支持UTF8的编码,无论输入输出都是UTF-8,所以如果你解析完一个XML得到的结果都是UTF8的,如果需要输出GB2312或者其它编码,需要ICONV来做转码(生成UTF8编码的文件也可以用它做),如果系统中没有安装iconv的话,需要安装libiconv。 1) 下载libiconv压缩包(例如libiconv-1.11.tar.gz) 2) 对压缩包进行解压缩tar xvzf libiconv-1.11.tar.gz 3) 进入解压缩后的文件夹中运行 ./

23、configure make make install三、关于XML:在开始研究 Libxml2 库之前,先了解一下XML的相关基础。XML 是一种基于文本的格式,它可用来创建能够通过各种语言和平台访问的结构化数据。它包括一系列类似 HTML 的标记,并以树型结构来对这些标记进行排列。例如,可参见清单 1 中介绍的简单文档。为了更清楚地显示 XML 的一般概念,下面是一个简化的XML文件。清单 1. 一个简单的 XML 文件 root delete 10清单 1 中的第一行是 XML 声明,它告诉负责处理 XML 的应用程序,即解析器,将要处理的 XML 的版本。大部分的文件使用版本 1.0

24、编写,但也有少量的版本 1.1 的文件。它还定义了所使用的编码。大部分文件使用 UTF-8,但是,XML 设计用来集成各种语言中的数据,包括那些不使用英语字母的语言。接下来出现的是元素。一个元素以开始标记 开始(如 ),并以结束标记 结束(如 ),其中使用斜线 (/) 来区别于开始标记。元素是 Node 的一种类型。XML 文档对象模型 (DOM) 定义了几种不同的 Nodes 类型,包括:Elements(如 files 或者 age)Attributes(如 units)Text(如 root 或者 10)元素可以具有子节点。例如,age 元素有一个子元素,即文本节点 10。XML 解析器

25、可以利用这种父子结构来遍历文档,甚至修改文档的结构或内容。LibXML2 是这样的解析器中的其中一种,并且文中的示例应用程序正是使用这种结构来实现该目的。对于各种不同的环境,有许多不同的解析器和库。LibXML2 是用于 UNIX 环境的解析器和库中最好的一种,并且经过扩展,它提供了对几种脚本语言的支持,如 Perl 和 Python。四、Libxml2中的数据类型和函数一个函数库中可能有几百种数据类型以及几千个函数,但是记住大师的话,90%的功能都是由30%的内容提供的。对于libxml2,我认为搞懂以下的数据类型和函数就足够了。1)内部字符类型xmlCharxmlChar是Libxml2中

26、的字符类型,库中所有字符、字符串都是基于这个数据类型。事实上它的定义是:xmlstring.htypedef unsigned char xmlChar;使用unsigned char作为内部字符格式是考虑到它能很好适应UTF-8编码,而UTF-8编码正是libxml2的内部编码,其它格式的编码要转换为这个编码才能在libxml2中使用。还经常可以看到使用xmlChar*作为字符串类型,很多函数会返回一个动态分配内存的xmlChar*变量,使用这样的函数时记得要手动删除内存。2) xmlChar相关函数如同标准c中的char类型一样,xmlChar也有动态内存分配、字符串操作等相关函数。例如x

27、mlMalloc是动态分配内存的函数;xmlFree是配套的释放内存函数;xmlStrcmp是字符串比较函数等等。基本上xmlChar字符串相关函数都在xmlstring.h中定义;而动态内存分配函数在xmlmemory.h中定义。3)xmlChar*与其它类型之间的转换另外要注意,因为总是要在xmlChar*和char*之间进行类型转换,所以定义了一个宏BAD_CAST,其定义如下:xmlstring.h#define BAD_CAST (xmlChar *)原则上来说,unsigned char和char之间进行强制类型转换是没有问题的。4)文档类型xmlDoc、指针xmlDocPtrxm

28、lDoc是一个struct,保存了一个xml的相关信息,例如文件名、文档类型、子节点等等;xmlDocPtr等于xmlDoc*,它搞成这个样子总让人以为是智能指针,其实不是,要手动删除的。xmlNewDoc函数创建一个新的文档指针。xmlParseFile函数以默认方式读入一个UTF-8格式的文档,并返回文档指针。xmlReadFile函数读入一个带有某种编码的xml文档,并返回文档指针;细节见libxml2参考手册。xmlFreeDoc释放文档指针。特别注意,当你调用xmlFreeDoc时,该文档所有包含的节点内存都被释放,所以一般来说不需要手动调用xmlFreeNode或者xmlFreeN

29、odeList来释放动态分配的节点内存,除非你把该节点从文档中移除了。一般来说,一个文档中所有节点都应该动态分配,然后加入文档,最后调用xmlFreeDoc一次释放所有节点申请的动态内存,这也是为什么我们很少看见xmlNodeFree的原因。xmlSaveFile将文档以默认方式存入一个文件。xmlSaveFormatFileEnc可将文档以某种编码/格式存入一个文件中。5)节点类型xmlNode、指针xmlNodePtr节点应该是xml中最重要的元素了,xmlNode代表了xml文档中的一个节点,实现为一个struct,内容很丰富:tree.htypedef struct _xmlNode

30、xmlNode;typedef xmlNode *xmlNodePtr;struct _xmlNode void *_private;/* application data */ xmlElementType type; /* type number, must be second ! */ const xmlChar *name; /* the name of the node, or the entity */ struct _xmlNode *children;/* parent-childs link */ struct _xmlNode *last; /* last child li

31、nk */ struct _xmlNode *parent;/* child-parent link */ struct _xmlNode *next; /* next sibling link*/ struct _xmlNode *prev; /* previous sibling link*/ struct _xmlDoc*doc;/* the containing document */ /* End of common part */ xmlNs *ns; /* pointer to the associated namespace */ xmlChar *content; /* th

32、e content */ struct _xmlAttr *properties;/* properties list */ xmlNs *nsDef; /* namespace definitions on this node */ void *psvi;/* for type/PSVI informations */ unsigned short line; /* line number */ unsigned short extra;/* extra data for XPath/XSLT */;可以看到,节点之间是以链表和树两种方式同时组织起来的,next和prev指针可以组成链表,而

33、parent和children可以组织为树。同时还有以下重要元素:节点中的文字内容:content;节点所属文档:doc;节点名字:name;节点的namespace:ns;节点属性列表:properties;Xml文档的操作其根本原理就是在节点之间移动、查询节点的各项信息,并进行增加、删除、修改的操作。xmlDocSetRootElement函数可以将一个节点设置为某个文档的根节点,这是将文档与节点连接起来的重要手段,当有了根结点以后,所有子节点就可以依次连接上根节点,从而组织成为一个xml树。6)节点集合类型xmlNodeSet、指针xmlNodeSetPtr节点集合代表一个由节点组成的变

34、量,节点集合只作为Xpath的查询结果而出现(XPATH的介绍见后面),因此被定义在xpath.h中,其定义如下:/* A node-set (an unordered collection of nodes without duplicates).*/typedef struct _xmlNodeSet xmlNodeSet;typedef xmlNodeSet *xmlNodeSetPtr;struct _xmlNodeSet int nodeNr; /* number of nodes in the set */ int nodeMax; /* size of the array as

35、allocated */ xmlNodePtr *nodeTab;/* array of nodes in no particular order */ /* with_ns to check wether namespace nodes should be looked at */;可以看出,节点集合有三个成员,分别是节点集合的节点数、最大可容纳的节点数,以及节点数组头指针。对节点集合中各个节点的访问方式很简单,如下:xmlNodeSetPtr nodeset = XPATH查询结果;for (int i = 0; i nodeNr; i+)nodeset-nodeTabi;注意,libxm

36、l2是一个c函数库,因此其函数和数据类型都使用c语言的方式来处理。如果是c+,我想我宁愿用STL中的vector来表示一个节点集合更好,而且没有内存泄漏或者溢出的担忧。五、使用Libxml2项目中要实现一个管理XML文件的后台程序,需要对XML文件进行创建,解析,修改,查找等操作,下面介绍如何利用libxml2提供的库来实现上述功能。1、创建XML文档:我们使用xmlNewDoc()来创建XML文档,然后使用xmlNewNode(),xmlNewChild(),xmlNewProp(),xmlNewText()等函数向XML文件中添加节点及子节点,设置元素和属性,创建完毕后用xmlSaveFo

37、rmatFileEnc()来保存XML文件到磁盘(该函数可以设置保存XML文件时的编码格式)。示例1: #include #include #include int main(int argc, char *argv) xmlDocPtr doc = NULL; /* document pointer */ xmlNodePtr root_node = NULL, node = NULL, node1 = NULL;/* node pointers */ / Creates a new document, a node and set it as a root node doc = xmlNe

38、wDoc(BAD_CAST 1.0); root_node = xmlNewNode(NULL, BAD_CAST root); xmlDocSetRootElement(doc, root_node); /creates a new node, which is attached as child node of root_node node. xmlNewChild(root_node, NULL, BAD_CAST node1,BAD_CAST content of node1); / xmlNewProp() creates attributes, which is attached

39、to an node. node=xmlNewChild(root_node, NULL, BAD_CAST node3, BAD_CASTnode has attributes); xmlNewProp(node, BAD_CAST attribute, BAD_CAST yes); /Here goes another way to create nodes. node = xmlNewNode(NULL, BAD_CAST node4); node1 = xmlNewText(BAD_CASTother way to create content); xmlAddChild(node,

40、node1); xmlAddChild(root_node, node); /Dumping document to stdio or file xmlSaveFormatFileEnc(argc 1 ? argv1 : -, doc, UTF-8, 1); /*free the document */ xmlFreeDoc(doc); xmlCleanupParser(); xmlMemoryDump();/debug memory for regression tests return(0); 编译:gcc -o xmlCreator xmlCreator.cpp-I/home/usr/l

41、ibxml2/xmlinst/include/libxml2/ -L /home/usr/libxml2/xmlinst/lib/ -lxml2 (绿色文字为libxml2安装路径) -I后接头文件目录 -L后接lib库目录2、解析XML文档 解析文档时仅仅需要文件名并只调用一个函数,并有错误检查,常用的相关函数有xmlParseFile(),xmlParseDoc(),获取文档指针后,就可以使用xmlDocGetRootElement()来获取根元素节点指针,利用该指针就可以在DOM树里漫游了,结束后要调用xmlFreeDoc()释放。示例2: xmlDocPtr doc; /定义解析文档指

42、针 xmlNodePtr cur; /定义结点指针(你需要它为了在各个结点间移动) xmlChar *key; doc = xmlReadFile(url, MY_ENCODING, 256); /解析文件 /*检查解析文档是否成功,如果不成功,libxml将指一个注册的错误并停止。一个常见错误是不适当的编码。XML标准文档除了用UTF-8或UTF-16外还可用其它编码保存。如果文档是这样,libxml将自动地为你转换到UTF-8。更多关于XML编码信息包含在XML标准中。*/ if (doc = NULL ) fprintf(stderr,Document not parsed succes

43、sfully. n); return; cur = xmlDocGetRootElement(doc); /确定文档根元素 /*检查确认当前文档中包含内容*/ if (cur = NULL) fprintf(stderr,empty documentn); xmlFreeDoc(doc); return; /*在这个例子中,我们需要确认文档是正确的类型。“root”是在这个示例中使用文档的根类型。*/ if (xmlStrcmp(cur-name, (const xmlChar *) root) fprintf(stderr,document of the wrong type, root n

44、ode != root); xmlFreeDoc(doc); return; cur = cur-xmlChildrenNode; while(cur!=NULL) if (!xmlStrcmp(cur-name, (const xmlChar *)keyword) key = xmlNodeListGetString(doc, cur-xmlChildrenNode, 1); printf(keyword: %sn, key); xmlFree(key); cur = cur-next; xmlFreeDoc(doc); 3、修改XML元素及属性等信息要修改XML文档里的元素及属性等信息,先

45、需要解析XML文档,获得一个节点指针(xmlNodePtr node),利用该节点指针漫游DOM树,就可以在XML文档中获取,修改,添加相关信息。示例3: 得到一个节点的内容: xmlChar *value = xmlNodeGetContent(node); 返回值value应该使用xmlFree(value)释放内存得到一个节点的某属性值: xmlChar *value = xmlGetProp(node, (const xmlChar *)prop1); 返回值需要xmlFree(value)释放内存 设置一个节点的内容: xmlNodeSetContent(node, (const x

46、mlChar *)test);设置一个节点的某属性值: xmlSetProp(node, (const xmlChar *)prop1, (const xmlChar *)v1); 添加一个节点元素: xmlNewTextChild(node, NULL, (const xmlChar *)keyword, (const xmlChar *)test Element); 添加一个节点属性: xmlNewProp(node, (const xmlChar *)prop1, (const xmlChar *)test Prop);4、查找XML节点有时候对一个XML文档我们可能只关心其中某一个或某

47、几个特定的Element的值或其属性,如果漫游DOM树将是很痛苦也很无聊的事,利用XPath可以非常方便地得到你想的Element。下面是一个自定义函数:示例4: xmlXPathObjectPtr get_nodeset(xmlDocPtr doc, const xmlChar *xpath) xmlXPathContextPtr context; xmlXPathObjectPtr result; context = xmlXPathNewContext(doc); if (context = NULL) printf(context is NULLn); return NULL; res

48、ult = xmlXPathEvalExpression(xpath, context); xmlXPathFreeContext(context); if (result = NULL) printf(xmlXPathEvalExpression return NULLn); return NULL; if (xmlXPathNodeSetIsEmpty(result-nodesetval) xmlXPathFreeObject(result); printf(nodeset is emptyn); return NULL; return result; 在doc指向的XML文档中查询满足x

49、path表达式条件的节点,返回满足这一条件的节点集合查询条件xpath的写法参见xpath相关资料。在查询完毕获取结果集后,就可以通过返回的 xmlXPathObjectPtr 结构访问该节点:示例5: xmlChar *xpath = (/root/node/key=keyword); xmlXPathObjectPtr app_result = get_nodeset(doc,xpath); if (app_result = NULL) printf(app_result is NULLn); return; int i = 0; xmlChar *value; if(app_result

50、) xmlNodeSetPtr nodeset = app_result-nodesetval; for (i=0; i nodeNr; i+) cur = nodeset-nodeTabi; cur = cur-xmlChildrenNode; while(cur!=NULL) value = xmlGetProp(cur,(const xmlChar *)key); if (value != NULL) printf(value: %snn, d_ConvertCharset(utf-8, GBK, (char *)value); xmlFree(value); value = xmlNodeGetContent(cur); if (value != NULL) printf(value: %snn, d_ConvertCharset(utf-8, GBK, (char *)value); xmlFree(value); xmlXPathFreeObject (app_result); 通过get_nodeset()返回的结果集,我们可以获取该节点的元

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论