Ubuntu在VMware里的使用教程入门篇_第1页
Ubuntu在VMware里的使用教程入门篇_第2页
Ubuntu在VMware里的使用教程入门篇_第3页
Ubuntu在VMware里的使用教程入门篇_第4页
Ubuntu在VMware里的使用教程入门篇_第5页
已阅读5页,还剩35页未读 继续免费阅读

下载本文档

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

文档简介

1、Ubuntu在VMware里的使用教程 入门篇对于Ubuntu系统的入门安装笔者在详解:Vmware虚拟机下Ubuntu 8.04安装一文中已经详细介绍了。关于整篇文章的评论笔者也大致略读一番,稍作整理大致包括以下几方面:为何没有解释VMware Tools安装以及网络配置,还有个别网友认为用VMware平台安装多此一举等。 笔者要强调对于前一篇关于详解安装的文章,毕竟安装Ubuntu系统的方法多种多样,由于篇幅的原因,不可能面面俱到。对于Ubuntu系统的安装非常重要,因为这直接影响到今后系统的日常应用。今天,就让笔者带领大家领略一下Ubuntu系统基本配置应用。由于本次关于Ubuntu系统

2、安装和应用都是在VMware(6.0.0版本)平台下完成,利用此方法的缺点就是无法体验到Ubuntu系统炫酷的桌面3D效果。说到这里,可能会有网友质疑平台版本和Ubuntu系统版本等问题,虽然都不是当前最新发布的版本,但是对于应用配置来说不会差很多。接下来,笔者就从如何安装VMware TOOLS、 如何升级中文支持等基本应用说起。VMware Tools安装VMware Workstation和Ubuntu系统完成之后,需要配置的第一步就是关于VMware Tools安装,因为这个会影响到用户实际操作体验。具体步骤如下:首先,点击VMware Workstation平台上菜单虚拟机(VM)安

3、装VMware Tools(Install VMware Tools),这时我们会在Ubuntu系统桌面上发现VMware Tools的光盘图标,系统会自动打开虚拟光驱中的文件,我们可以看到VMwareTools-6.0.0-45731.i386.rpm和VMwareTools-6.0.0-45731.tar.gz两个文件。安装VMware Tools(点击查看大图)这里再次强调一下对于VMware Tools,从简单应用的角度来说,不安装VMware Tools一般不会影响到具体应用,但是由于虚拟机环境下Ubuntu系统分辨率等问题就是依靠VMware Tools来实现的,安装目的也是为了给

4、用户一个更好的体验。鼠标点击“Install VMware Tools”后,桌面会出现一个VMware Tools类似光驱标识的图标,并且系统会自己找到对应VMware Tools包含的文件(其中一个后缀名为.rpm是Redhat平台版本,另一个后缀名为.tar.gz就是Ubuntu系统下的版本)。VMware Tools虚拟镜像和两个应用文件(点击查看大图)这里我们在虚拟PC裸机上安装的是Ubuntu系统,所以我们在利用Ubuntu终端安装的时候需要运行.tar.gz文件,具体做法是先打开Ubuntu系统的终端。很简单,依次点击Application附件终端,会出现一个类似于Windows系

5、统开始菜单附件命令提示符的窗口。如下图: Ubuntu系统终端(点击查看大图)此时,我们在终端内输入:$ tar zxf /media/cdrom/VMwareTools-6.0.0-45731.tar.gz(说明:文件解压)按下“回车”键$ cd vmware-tools-distrib(进入解压后对应文件夹中)再按下“回车”键,系统会转至“/vmware-tools-distrib”文件夹下,Ubuntu终端上会显示如下:此时键入sudo ./vmware-install.pl(安装软件)来完成安装工作。liufengliufeng-desktop:/vmware-tools-distri

6、b$ sudo ./vmware-install.pl(安装软件)如果用户在安装Ubuntu系统的时候设置了用户名和密码,那么在Ubuntu系统下安装软件时,就会提示大家输入密码,这里我们输入密码之后便开始安装。sudo password for liufeng: *提醒用户注意的是,在输入密码回车之后系统会自行进行安装文件工作,我们不用太在意它的具体提示,直接回车(要键入多下回车键)就可以实现VMware Tools的安装工作。其实,就像大家日常在Windows系统下安装软件一样,只不过Windows系统下是图形界面的方式,比较直观。安装完成后最终会在终端上显示(点击查看大图)经过很多次键入

7、回车键之后,最终大家会看到Enjoy,-the VMware team字样,这表示提示安装成功(如上图)。还有一点值得一提的就是,在安装的过程中系统会提示关于分辨率的问题,如下图一共提供了15项分辨率组合模式,系统会自动识别你显示器的最大值,这里系统显示的是6,我们只需要按照默认情况下的配置按下回车继续安装即可。 安装过程中分辨率的选择(点击查看大图)VMware Tools安装完成之后,我们只需要重新启动一下Ubuntu系统之后,便可以看到,新的启动页面会根据你的显示器大小自行调节。另外,在虚拟桌面平台左下角的早先未安装的带有黑叹号的黄色三角提示(没有安装VMware Tools)也不见了,

8、取而代之的是“VMware Tools installed successfully”字样,如下图:提示“VMware Tools installed successfully”(红色区域)Ubuntu系统中文包更新VMware Tools安装告一段落,怎么样其实VMware Tools的安装很方便并且安装完成后用户操作体验也会得到不少提升。这个问题解决了,但是关于系统操作界面一半是英文一半是中文,这个看起来是比较麻烦的。不要紧,下面笔者向大家介绍如何设置安装更新中文语言包,其实也很简单。首先,依次点击Ubuntu系统中的System选项系统管理Language Support,随后会出现如下

9、“汉语选项图”界面。从菜单选择语言支持选项(点击查看大图)由于当初笔者在Vmware平台上安装Ubuntu系统时选择的语言就是中文安装,所以这里面的默认语言(Default language)会自动选中汉语一项。我们只需要在Supported Languages选项列表中选择“汉语”,对应在“Support”列上勾选,如下图:汉语选项图(点击查看大图)随后,点击OK即可,这时会弹出键入密码的对话框,键入系统初装时设置的密码(也就是用户登陆时的密码)后,点击OK进入安装。键入密码(点击查看大图)此时,系统会弹出一个对话框如下图,本次需要更新24个文件。用户只需要耐心等待即可。在更新语言包的过程中

10、比较慢,更新速度完全是受到“下载服务器”的影响,我们这里选择在线更新服务器源为其它国家。开始更新语言包(点击查看大图)为了提高系统各方面的更新速度,我们可以设定软件源(需要更新下载的远程服务器源),依次点击系统系统管理软件源后,弹出如下框:见图1寻找软件源设置(点击查看大图)点击“下载自”(图1)(点击查看大图)这里我们没有选择默认的中国服务器作为系统更新的软件源,我们选择的是其它国家的更新,相对来说比较快。如下图2:服务器更新列表可以随便选择(图2)(点击查看大图)大概经过很长时间的更新完成之后,重新启动Ubuntu 系统之后,我们便可以看到系统大部分已经更新为中文字样。说到这里,不少网友会

11、质疑关于Ubuntu系统的上网设置等问题。由于笔者在前一篇详解安装文章中,建立这台虚拟机时设置的网络连接形式是共享宿主机的网络。笔者的计算机是在公司的局域网内,IP地址是自动获取的,所以不需要做过多的设置,因为在Ubuntu系统安装的时候选择的就是“共享宿主机的网络”。所以这里面自然就可以轻松实现上网。对于Ubuntu系统的网络设置过程简单介绍给大家,鼠标选择系统右上角的网络图标,左键单击选择手动设置便可出现网络设置对话框,从而根据用户不同网络环境来设置网络,非常方便。网络设置(点击查看大图)很多网友关注最多的应该是VMware平台下的Ubuntu系统是否支持3D动态桌面效果,这里笔者经过调试

12、设置并没有实现此功能,如下图:无法开启桌面效果(点击查看大图)总结:Ubuntu的全部都可以通过网络进行更新或扩展,这些可供Ubuntu下载使用的软件通过多种形式分散或集中的库存在全球各地,这些远端的可用程序仓库对我们来说就是可供在线安装、更新的软件源。Ubuntu系统的入门级应用主要集中在语言包更新,而在VMware 环境下的Ubuntu系统应用,首先要解决VMware Tools安装等问题,这样在日后的系统体验和应用过程中更加方便快捷。希望以上的基本设置会对大家有所帮助。对于今后更加深入的关于Ubuntu系统下的应用,笔者也正在探索尝试,也欢迎高人指点迷津,本着学习和试用的态度,更多的深入

13、应用请您继续关注ZOL服务器频道的相关报道。PS:欢迎相关技术人员和Ubuntu系统玩家交流联系方式:Email:liu.feng附录资料:不需要的可以自行删除 libxml2应用实例Libxml2 是一个xml的c语言版的解析器,本来是为Gnome项目开发的工具,是一个基于MIT License的免费开源软件。它除了支持c语言版以外,还支持c+、PHP、Pascal、Ruby、Tcl等语言的绑定,能在Windows、Linux、Solaris、MacOsX等平台上运行。功能还是相当强大的,相信满足一般用户需求没有任何问题。二、 Libxml2安装:一般如果在安装系统的时候选中了所有开发库和开

14、发工具的话(Fedora Core系列下),应该不用安装,下面介绍一下手动安装: 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 说

15、明:为了结构清晰,最好将libxml2不安装在解压目录中。安装完成后就可以使用简单的代码解析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)

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

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

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

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

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

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

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

23、 struct _xmlNode 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;

24、 /* last child link */ 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 */ xmlCha

25、r *content; /* the 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 */;可以看到,节点之间是以链表和树两种方式同时组织起来的,ne

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

27、tr节点集合代表一个由节点组成的变量,节点集合只作为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

28、 of the array as 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-

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

30、性,创建完毕后用xmlSaveFormatFileEnc()来保存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

31、 node doc = xmlNewDoc(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, w

32、hich is attached 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); x

33、mlAddChild(node, 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

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

35、Ptr doc; /定义解析文档指针 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

36、not parsed successfully. 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 w

37、rong type, root node != 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元素及属性等信息要修改

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

39、nt(node, (const xmlChar *)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节点有时候对一个XM

40、L文档我们可能只关心其中某一个或某几个特定的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);

41、 return NULL; result = 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; 在

42、doc指向的XML文档中查询满足xpath表达式条件的节点,返回满足这一条件的节点集合查询条件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 *val

43、ue; if(app_result) 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(valu

44、e); value = xmlNodeGetContent(cur); if (value != NULL) printf(value: %snn, d_ConvertCharset(utf-8, GBK, (char *)value); xmlFree(value); xmlXPathFreeObject (app_result); 通过get_nodeset()返回的结果集,我们可以获取该节点的元素及属性,也可以修改该节点的值。示例中在获取值打印的时候用到 d_ConvertCharset()函数来改变编码格式为GBK,以方便正确读取可能的中文字符。5、编码问题由于Libxml一般以UTF-8格式保存和操纵数据,如果你的程序使用其它的数据格式,比如中文字符(GB2312,GBK编码),就必须使用Libxml函数转换到UTF-8。如果你想你的程序以除UTF-8外的其它编码方式输出也必须做转换。 下面的示例程序

温馨提示

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

评论

0/150

提交评论