热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

使用VBA编辑XMLrootelement

我是XML的新手。我使用以下函数创建一个xml文件。我想更改代码以向其根元素添加

我是XML的新手。我使用以下函数创建一个xml文件。
我想更改代码以向其根元素添加更多详细信息。
您可以参考所附图片以达到我的目的。

Function fnCreateXmlNew()
Dim objDom As DOMDocument
Dim objRootElem As IXMLDOMElement
Dim objMemberElem As IXMLDOMElement
Dim objMemberRel As IXMLDOMAttribute
Dim objMemberName As IXMLDOMElement
Set objDom = New DOMDocument
objDom.appendChild objDom.createProcessingInstruction("xml","version='1.0' encoding='UTF-8' standalOne=""yes""")
Set objRootElem = objDom.createElement("_XPXML")
objDom.appendChild objRootElem
XMLFileName = "C:\Users\SHIVAMAIN\Documents\xml\TEST.xml"
Set ParentNode = objDom.SelectSingleNode("_XPXML")
Set childNode = objDom.createElement("_FTrans")
ParentNode.appendChild childNode
Set nodeAttribute = objDom.createAttribute("Unit")
nodeAttribute.NodeValue = 2
childNode.setattributeNode nodeAttribute
Set nodeAttribute = objDom.createAttribute("UnitAmount")
nodeAttribute.NodeValue = 525.3
childNode.setattributeNode nodeAttribute
Set nodeAttribute = objDom.createAttribute("RefN")
nodeAttribute.NodeValue = 0
childNode.setattributeNode nodeAttribute
Set nodeAttribute = objDom.createAttribute("Desc")
nodeAttribute.NodeValue = "ÈÇÈÊ ÝǘÊæÑ ÝÑæÔ1"
childNode.setattributeNode nodeAttribute
Set nodeAttribute = objDom.createAttribute("Cre")
nodeAttribute.NodeValue = 0
childNode.setattributeNode nodeAttribute
Set nodeAttribute = objDom.createAttribute("Deb")
nodeAttribute.NodeValue = 3798385
childNode.setattributeNode nodeAttribute
Set nodeAttribute = objDom.createAttribute("Det2")
nodeAttribute.NodeValue = "16/0002"
childNode.setattributeNode nodeAttribute
Set nodeAttribute = objDom.createAttribute("Det1")
nodeAttribute.NodeValue = "03/0654"
childNode.setattributeNode nodeAttribute
Set nodeAttribute = objDom.createAttribute("acc")
nodeAttribute.NodeValue = "1/0/01/02"
childNode.setattributeNode nodeAttribute
Set childNode = objDom.createElement("_FTrans")
ParentNode.appendChild childNode
Set nodeAttribute = objDom.createAttribute("Unit")
nodeAttribute.NodeValue = 2
childNode.setattributeNode nodeAttribute
Set nodeAttribute = objDom.createAttribute("UnitAmount")
nodeAttribute.NodeValue = 54.6
childNode.setattributeNode nodeAttribute
Set nodeAttribute = objDom.createAttribute("RefN")
nodeAttribute.NodeValue = 645000
childNode.setattributeNode nodeAttribute
Set nodeAttribute = objDom.createAttribute("ODesc")
nodeAttribute.NodeValue = 41970130298#
childNode.setattributeNode nodeAttribute
Set nodeAttribute = objDom.createAttribute("Desc")
nodeAttribute.NodeValue = "ÈÇÈÊ ÝǘÊæÑ ÝÑæÔ"
childNode.setattributeNode nodeAttribute
Set nodeAttribute = objDom.createAttribute("Cre")
nodeAttribute.NodeValue = 352170
childNode.setattributeNode nodeAttribute
Set nodeAttribute = objDom.createAttribute("Deb")
nodeAttribute.NodeValue = 0
childNode.setattributeNode nodeAttribute
Set nodeAttribute = objDom.createAttribute("Det2")
nodeAttribute.NodeValue = "03/0654"
childNode.setattributeNode nodeAttribute
Set nodeAttribute = objDom.createAttribute("Det1")
nodeAttribute.NodeValue = "09/1571"
childNode.setattributeNode nodeAttribute
Set nodeAttribute = objDom.createAttribute("acc")
nodeAttribute.NodeValue = "4/0/00/01"
childNode.setattributeNode nodeAttribute
objDom.Save (XMLFileName)
End Function

使用VBA编辑XML rootelement


在创建根元素之后仅使用setAttribute属性。在下面的示例中,相应地填写...

...
' ROOT ELEMENT
Set objRootElem = objDom.createElement("_XPXML")
With objRootElem
.setAttribute "Desc",""
.setAttribute "AppId","1"
.setAttribute "Ver","802"
.setAttribute "Srv","SHN_ACCSERVER"
.setAttribute "DBN","_AccXP_SHN98"
End With
objDom.appendChild objRootElem
' ROOT CHILD NODES
Set childNode = objDom.createElement("_FTrans")
With childNode
.setAttribute "Unit","2"
.setAttribute "UnitAmount","54.6"
.setAttribute "RefN","645000"
...
End With
objRootElem.appendChild
...

推荐阅读
  • MyBatis多表查询与动态SQL使用
    本文介绍了MyBatis多表查询与动态SQL的使用方法,包括一对一查询和一对多查询。同时还介绍了动态SQL的使用,包括if标签、trim标签、where标签、set标签和foreach标签的用法。文章还提供了相关的配置信息和示例代码。 ... [详细]
  • 本文介绍了Android 7的学习笔记总结,包括最新的移动架构视频、大厂安卓面试真题和项目实战源码讲义。同时还分享了开源的完整内容,并提醒读者在使用FileProvider适配时要注意不同模块的AndroidManfiest.xml中配置的xml文件名必须不同,否则会出现问题。 ... [详细]
  • YOLOv7基于自己的数据集从零构建模型完整训练、推理计算超详细教程
    本文介绍了关于人工智能、神经网络和深度学习的知识点,并提供了YOLOv7基于自己的数据集从零构建模型完整训练、推理计算的详细教程。文章还提到了郑州最低生活保障的话题。对于从事目标检测任务的人来说,YOLO是一个熟悉的模型。文章还提到了yolov4和yolov6的相关内容,以及选择模型的优化思路。 ... [详细]
  • 本文介绍了使用kotlin实现动画效果的方法,包括上下移动、放大缩小、旋转等功能。通过代码示例演示了如何使用ObjectAnimator和AnimatorSet来实现动画效果,并提供了实现抖动效果的代码。同时还介绍了如何使用translationY和translationX来实现上下和左右移动的效果。最后还提供了一个anim_small.xml文件的代码示例,可以用来实现放大缩小的效果。 ... [详细]
  • 本文介绍了Java工具类库Hutool,该工具包封装了对文件、流、加密解密、转码、正则、线程、XML等JDK方法的封装,并提供了各种Util工具类。同时,还介绍了Hutool的组件,包括动态代理、布隆过滤、缓存、定时任务等功能。该工具包可以简化Java代码,提高开发效率。 ... [详细]
  • XML介绍与使用的概述及标签规则
    本文介绍了XML的基本概念和用途,包括XML的可扩展性和标签的自定义特性。同时还详细解释了XML标签的规则,包括标签的尖括号和合法标识符的组成,标签必须成对出现的原则以及特殊标签的使用方法。通过本文的阅读,读者可以对XML的基本知识有一个全面的了解。 ... [详细]
  • Android系统移植与调试之如何修改Android设备状态条上音量加减键在横竖屏切换的时候的显示于隐藏
    本文介绍了如何修改Android设备状态条上音量加减键在横竖屏切换时的显示与隐藏。通过修改系统文件system_bar.xml实现了该功能,并分享了解决思路和经验。 ... [详细]
  • 突破MIUI14限制,自定义胶囊图标、大图标样式,支持任意APP
    本文介绍了如何突破MIUI14的限制,实现自定义胶囊图标和大图标样式,并支持任意APP。需要一定的动手能力和主题设计师账号权限或者会主题pojie。详细步骤包括应用包名获取、素材制作和封包获取等。 ... [详细]
  • 树莓派语音控制的配置方法和步骤
    本文介绍了在树莓派上实现语音控制的配置方法和步骤。首先感谢博主Eoman的帮助,文章参考了他的内容。树莓派的配置需要通过sudo raspi-config进行,然后使用Eoman的控制方法,即安装wiringPi库并编写控制引脚的脚本。具体的安装步骤和脚本编写方法在文章中详细介绍。 ... [详细]
  • iOS超签签名服务器搭建及其优劣势
    本文介绍了搭建iOS超签签名服务器的原因和优势,包括不掉签、用户可以直接安装不需要信任、体验好等。同时也提到了超签的劣势,即一个证书只能安装100个,成本较高。文章还详细介绍了超签的实现原理,包括用户请求服务器安装mobileconfig文件、服务器调用苹果接口添加udid等步骤。最后,还提到了生成mobileconfig文件和导出AppleWorldwideDeveloperRelationsCertificationAuthority证书的方法。 ... [详细]
  • 本文介绍了如何使用PHP代码将表格导出为UTF8格式的Excel文件。首先,需要连接到数据库并获取表格的列名。然后,设置文件名和文件指针,并将内容写入文件。最后,设置响应头部,将文件作为附件下载。 ... [详细]
  • Activiti7流程定义开发笔记
    本文介绍了Activiti7流程定义的开发笔记,包括流程定义的概念、使用activiti-explorer和activiti-eclipse-designer进行建模的方式,以及生成流程图的方法。还介绍了流程定义部署的概念和步骤,包括将bpmn和png文件添加部署到activiti数据库中的方法,以及使用ZIP包进行部署的方式。同时还提到了activiti.cfg.xml文件的作用。 ... [详细]
  • 在本教程中,我们将看到如何使用FLASK制作第一个用于机器学习模型的RESTAPI。我们将从创建机器学习模型开始。然后,我们将看到使用Flask创建AP ... [详细]
  • 开发笔记:加密&json&StringIO模块&BytesIO模块
    篇首语:本文由编程笔记#小编为大家整理,主要介绍了加密&json&StringIO模块&BytesIO模块相关的知识,希望对你有一定的参考价值。一、加密加密 ... [详细]
  • HDFS2.x新特性
    一、集群间数据拷贝scp实现两个远程主机之间的文件复制scp-rhello.txtroothadoop103:useratguiguhello.txt推pushscp-rr ... [详细]
author-avatar
书友31617792
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有