VBA编写Ribbon Custom UI编辑器07——写入xml
时间:2022-07-24
本文章向大家介绍VBA编写Ribbon Custom UI编辑器07——写入xml,主要内容包括其使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。
写入custom.xml步骤:
- 从Excel中读取数据并转换为xml格式的文本
- 然后转换编码
- 使用类模块CPKZip的功能,将custom.xml写入(CPKZip的写入功能下次介绍)
这里需要注意的是,如果某个Office文件没有custom.xml,除了要写入custom.xml之外,还必须在_rels/.rels文件后面,增加一条Relationship:
'写入customUI.xml
Sub WriteCustomUI()
Dim arr()
Dim sXML As String
arr = Range("A1").CurrentRegion.Value
'单元格内容转换为xml文本
sXML = Array2XMLString(arr)
If VBA.Len(sXML) = 0 Then
MsgBox "请在单元格中设置customUI"
Exit Sub
End If
Dim bucs2() As Byte
bucs2 = sXML
'转换编码
Dim bUTF8() As Byte
Dim ret As String
ret = ToUTF8(bucs2, bUTF8)
If VBA.Len(ret) Then
MsgBox "编码转换出错:" & vbNewLine & ret
Exit Sub
End If
'检查是否设置了目标文件
If VBA.Len(FileName) = 0 Then
FileName = SelectFile()
If VBA.Len(FileName) = 0 Then Exit Sub
End If
'备份文件
If bBakFile Then
VBA.FileCopy FileName, FileName & ".备份" & VBA.Format(VBA.Now(), "yyyymmddhhmmss")
End If
Dim zip As CPKZip
Set zip = NewCPKZip()
'解析文件
ret = zip.Parse(FileName)
If VBA.Len(ret) Then
MsgBox ret
Exit Sub
End If
'判断是否存在CUSTOMUI_NAME,不存在的情况下还要更新rel
Dim fs() As String
fs = zip.Files()
Dim i As Long
For i = 0 To UBound(fs)
If fs(i) = CUSTOMUI_NAME Then
Exit For
End If
Next
Dim b() As Byte '记录_rels/.rels
If i = UBound(fs) + 1 Then
'添加rel
ret = zip.UnZipFile("_rels/.rels", b)
If VBA.Len(ret) Then
MsgBox ret
Exit Sub
End If
ret = FromUTF8(b, bucs2)
If VBA.Len(ret) Then
MsgBox ret
Exit Sub
End If
'将最后的</Relationships>替换为<Relationship Id="VBAPKZIP" Type="http://schemas.microsoft.com/office/2006/relationships/ui/extensibility" Target="customUI/customUI.xml"/></Relationships>
Dim str As String
str = bucs2
str = VBA.Left$(str, VBA.Len(str) - VBA.Len("</Relationships>"))
str = str & "<Relationship Id=""VBAPKZIP"" Type=""http://schemas.microsoft.com/office/2006/relationships/ui/extensibility"" Target=""customUI/customUI.xml""/></Relationships>"
bucs2 = str
ret = ToUTF8(bucs2, b)
If VBA.Len(ret) Then
MsgBox ret
Exit Sub
End If
ret = zip.AddFile("_rels/.rels", b)
If VBA.Len(ret) Then
MsgBox ret
Exit Sub
End If
End If
'添加customUI.xml
ret = zip.AddFile(CUSTOMUI_NAME, bUTF8)
If VBA.Len(ret) Then
MsgBox ret
Exit Sub
End If
Set zip = Nothing
End Sub
- 纠结的paste格式问题(未解决) (r5笔记第26天)
- 由MySQL中的falcon存储引擎引申的八卦杂谈(r5笔记第23天)
- 12.观察者/状态模式
- 数据补丁中需要注意的几个问题(r5笔记第21天)
- 简单对比MySQL和Oracle中的一个sql解析细节 (r5笔记第40天)
- 关于Oracle和MySQL中的无密码登录 (r5笔记第39天)
- 快速定位隐蔽的sql性能问题及调优(r5笔记第38天)
- 关于统计信息过期的性能落差(r5笔记第36天)
- 系统级alias vs Oracle ADR功能(r5笔记第35天)
- 关于收缩数据文件的尝试(r5笔记第34天)
- 搭建dataguard碰到的几个小问题(r5笔记第33天)
- TP-LINK 远程代码执行漏洞 CVE-2017-13772 趣谈
- 执行计划中的COLLECTION ITERATOR PICKLER FETCH导致的性能问题 (r5笔记第49天)
- dataguard switchover的自动化脚本实现 (r5笔记第48天)
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法
- 代数效应与React
- spring之在配置Bean时如何关联不同的Bean
- spring之级联属性赋值的两种方式
- hz(赫兹)
- spring之为java.util.Properties类型的属性进行赋值
- python之类也是一个对象
- spring之使用命名空间p来简化bean的配置
- SpringBoot 2.X中的@Async和Java8中的completableFuture的使用比较
- c语言之创建字符串的两种方式
- 机器学习-文本分类(1)之独热编码、词袋模型、N-gram、TF-IDF
- spring之自动装配的三种方式
- 机器学习-文本分类(2)-新闻文本分类
- Mysql5.6版本新增列,执行DDL的时候竟然锁表了,这应该是是最好的解决办法之一了!!
- spring之bean的作用域
- spring之spring表达式语言:SpEL