XML常用函数 .

http://blog.csdn.net/ly61baby/article/details/6458383

 

3.3 重要操作

  3.3.1 创建XML文档

  创建一个xml文档流程如下:

  l 用xmlNewDoc函数创建一个文档指针doc;

  l 用xmlNewNode函数创建一个节点指针root_node;

  l 用xmlDocSetRootElement将root_node设置为doc的根结点;

  l 给root_node新增一系列的子节点,并设置子节点的内容和属性;

  l 用xmlSaveFile将xml文档存入文件;

  l 用xmlFreeDoc函数关闭文档指针,并断根本文档中所有节点动态声请的内存

  示例代码:

   #include <stdio.h> #include <libxml/parser.h> #include <libxml/tree.h> int main(int argc , char **argv) { xmlDocPtr pdoc = NULL; xmlNodePtr proot_node = NULL ,pnode = NULL , pnode1 = NULL; // 创造一个新文档并设置要root节点

  // 在XML文档中有且只有一个root节点

  pdoc = xmlNewDoc( BAD_CAST "1.0");

  proot_node = xmlNewNode(NULL , BAD_CAST "plist");

  xmlNewProp(proot_node , BAD_CAST "version" , BAD_CAST "1.0");

  xmlDocSetRootElement(pdoc , proot_node);

  pnode = xmlNewNode( NULL , BAD_CAST "dict" );

  // 创造root节点的子节点

  xmlNewChild(pnode , NULL , BAD_CAST "key" , BAD_CAST "info");

  pnode1 = xmlNewNode( NULL , BAD_CAST "dict" );

  //保存文档

  xmlSaveFormatFileEnc(argc > 1 ? argv[1] : "-", pdoc, "UTF-8", 1);

  //释放文档指针

  xmlFreeDoc(pdoc);

  xmlCleanupParser();

  xmlMemoryDump(); //debug memory for regression tests

  return(0);

  } 涉及相关函数:

  xmlNewDoc,xmlNewNode,xmlDocSetRootElement,xmlSaveFile,xmlFreeDoc。

  3.3.2 解释文档

  解析一个xml文档,从其中取出想要的信息,例如节点中包含的书契,或者某个节点的属性,其流程如下:

  l 用xmlReadFile函数读出一个文档指针doc;

  l 用xmlDocGetRootElement函数获得根节点curNode;

  l curNode->xmlChildrenNode就是根节点的子节点集合;

  l 轮询子节点集合,找到所需的节点,用xmlNodeGetContent取出其内容;

  l 用xmlHasProp查找含有某个属性的节点;

  l 取出该节点的属性集合,用xmlGetProp取出其属性值;

  l 用xmlFreeDoc函数关闭文档指针,并断根本文档中所有节点动态声请的内存。

  注意:节点列表的指针依然是xmlNodePtr,属性列表的指针也是xmlAttrPtr,并没有xmlNodeList或者xmlAttrList这样的类型。看作列表的时候使用它们的next和prev链表指针来进行轮询。只有在Xpath中有xmlNodeSet这种类型,其使用方法前边已经先容了。

  示例代码:

  int main(int argc , char **argv) { xmlDocPtr pdoc = NULL; xmlNodePtr proot=NULL , 电脑urnode = NULL; char *psfilename; if (argc < 1) { printf("error: Usage: %s filename/n" , argv[0]); exit(1); } psfilename = argv[1]; pdoc = xmlReadFile(psfilename ,"UTF-8",XML_PARSE_RECOVER); if(NULL == pdoc) { printf("error: open file %s" , psfilename); exit(1); } 电脑urnode = xmlDocGetRootElement(pdoc); if(NULL == 电脑urnode) { printf("error: empty document %s" , psfilename); exit(1); } if(xmlStrcmp(电脑urnode->name , BAD_CAST "plist") != 0) { printf("error document " ); exit(1); } if(xmlHasProp(电脑urnode ,BAD_CAST "version")) { xmlChar *szAttr = xmlGetProp(电脑urnode, BAD_CAST "version"); printf("get version : %s /n" , szAttr); } xmlFreeDoc(pdoc); xmlCleanupParser(); return 0; } 涉及函数:

  xmlParseFile,xmlReadFile,xmlDocGetRootElement,xmlHasProp,xmlGetProp。其中xmlParseFile和xmlReadFile都具有打开XML文件的功能,xmlParseFile函数以默认方式读入一个UTF-8格局的文档,并返回文档指针。xmlReadFile函数读入一个带有某种编码的xml文档,并返回文档指针。 3.3.3 修改XML

  有了上边的基础,修改xml文档的内容就很简单了。起首打开一个已经存在的xml文档,顺着根结点找到需要新增、删去、修改之处,调用相应的xml函数对节点进行增、删、改操作。

  示例代码:

  #include <libxml/parser.h> #include <iostream.h> int main(int argc, char* argv[]) { xmlDocPtr doc; //界说解析文档指针

  xmlNodePtr curNode; //界说结点指针你需要它为了在各个结点间移动)

  char *szDocName;

  if (argc <= 1)

  {

  printf("Usage: %s docname/n", argv[0]);

  return(0);

  }

  szDocName = argv[1];

  doc = xmlReadFile(szDocName,"GB2312",XML_PARSE_RECOVER); //解析文件

  if (NULL == doc)

  {

  fprintf(stderr,"Document not parsed successfully. /n");

  return -1;

  }

  curNode = xmlDocGetRootElement(doc);

  if (NULL == curNode)

  {

  fprintf(stderr,"empty document/n");

  xmlFreeDoc(doc);

  return -1;

  }

  curNode = curNode->children;

  while (NULL != curNode)

  {

  //删去newNode1

  if (!xmlStrcmp(curNode->name, BAD_CAST "newNode1"))

  {

  xmlNodePtr tempNode;

  tempNode = curNode->next;

  xmlUnlinkNode(curNode);

  xmlFreeNode(curNode);

  curNode = tempNode;

  continue;

  }

  //修改node2的属性值

  if (!xmlStrcmp(curNode->name, BAD_CAST "node2"))

  {

  xmlSetProp(curNode,BAD_CAST "attribute", BAD_CAST "no");

  }

  //修改newNode2的内容

  if (!xmlStrcmp(curNode->name, BAD_CAST "newNode2"))

  {

  xmlNodeSetContent(curNode, BAD_CAST "content changed");

  }

  //增加一个属性

  if (!xmlStrcmp(curNode->name, BAD_CAST "newNode3"))

  {

  xmlNewProp(curNode, BAD_CAST "newAttr", BAD_CAST "YES");

  }

  //增加一个子节点

  if (!xmlStrcmp(curNode->name, BAD_CAST "son"))

  {

  xmlNewTextChild(curNode, NULL, BAD_CAST "newGrandSon", BAD_CAST "new content");

  }

  curNode = curNode->next;

  • 2
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: paddlepaddle是一种开源深度学习框架,xml2json.py是该框架中的一个文件。 xml2json.py是一个用于将XML格式的数据转换为JSON格式的工具。在深度学习中,数据通常以不同的格式存在,而XML和JSON都是常用的数据交换格式之一。通过将XML数据转换为JSON格式,可以更方便地在深度学习框架中进行数据处理和分析。 在使用paddlepaddle进行深度学习任务时,我们可能需要使用xml2json.py来处理特定的数据集。例如,如果我们有一个XML格式的图像标注数据集,可以使用xml2json.py将其转换为JSON格式,方便地读取和处理。 使用xml2json.py非常简单。我们只需要执行相应的命令或调用相关的函数,即可将XML数据转换为JSON格式。具体的使用方法可以参考相关的文档和代码示例。 总的来说,paddlepaddle的xml2json.py是一个用于将XML数据转换为JSON格式的工具,在深度学习任务中起到了简化数据处理流程的作用。在使用该工具时,我们只需要按照相应的方法调用,即可快速地将XML格式的数据转换为JSON格式,方便进一步的数据分析和处理。 ### 回答2: paddlepaddle xml2json.py是一个用于将XML文件转换为JSON格式的Python脚本。XML是一种标记语言,常用于在不同应用程序之间交换数据。JSON是一种轻量级的数据交换格式,在Web应用程序中广泛使用。 使用paddlepaddle xml2json.py脚本可以方便地将XML文件转换为JSON格式的数据。这对于那些需要将XML数据转换为JSON的开发人员和数据分析师来说非常有用。 使用该脚本的步骤如下: 1. 首先,确保已经安装了Python和paddlepaddle库。可以在命令行中运行pip install paddlepaddle命令来安装该库。 2. 将要转换的XML文件放置在与xml2json.py脚本相同的目录中。 3. 打开终端或命令行窗口,并导航到xml2json.py脚本所在的目录。 4. 运行以下命令来执行转换: python xml2json.py your_xml_file.xml 值得注意的是,将your_xml_file.xml替换为实际的XML文件名。 5. 执行完上述命令后,脚本将读取XML文件并将其转换为JSON格式。转换后的JSON数据会在终端或命令行窗口中显示出来。 使用paddlepaddle xml2json.py脚本可以帮助用户快速、简便地将XML数据转换为JSON格式。这对于进一步处理和分析数据非常有帮助,尤其是在涉及不同格式的数据交换和处理时。通过将数据转换为JSON格式,可以更方便地在不同的应用程序和平台之间进行数据交互和共享。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值