博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
如何在open xml excel 中存储自定义xml数据?
阅读量:6688 次
发布时间:2019-06-25

本文共 2154 字,大约阅读时间需要 7 分钟。

如何在open xml excel 中存储自定义xml数据?

而且不能放在隐藏的cell单元格内,也不能放在隐藏的sheet内,要类似web网站的Application变量,但还不能是VBA和宏之类的,要对用户不可见,但是对开发者可见。

曾经试过两个方法:

1.在styles.xml或sheet1.xml中的Extension (extLst/ext)节点下添加自定义节点,用来存储自己的数据。

具体xml节点如下:

  <extLst>

    <ext uri="{EB79DEF2-80B8-43e5-95BD-54CBDDF9020C}" xmlns:x14="http://schemas.microsoft.com/office/spreadsheetml/2009/9/main">

      <x14:slicerStyles defaultSlicerStyle="SlicerStyleLight1"/>

    </ext>

  </extLst>

Worksheet的xml里可以有extLst,stylesheet的xml里也可以有extLst,但Worksheet里的不知道怎么用,常见的是在stylesheet里.

虽然Extension (extLst/ext)节点貌似是供扩展数据使用的,但是当使用excel打开此文件并保存时,此自定义节点因为不是excel内置的内容就被清掉了,不能达到目的。

这个地方始终没搞太明白它究竟能做什么?不能做什么?如果哪位兄弟知道,还盼给讲解一下,下面是msdn上相关的链接: 

ExtensionList Class

Defines the ExtensionList Class.When the object is serialized out as xml, its qualified name is x:extLst.

 

Extension Class

Extension. When the object is serialized out as xml, its qualified name is x:ext.

  

2.使用customed defined xml。

从Open Xml架构图入手,发现Custom Defined XML或许可用,如下图:

 

从msdn的文章 (Custom XML Parts Overview ) 中摘到:

"You can embed XML data in documents for some Microsoft Office applications. When you embed XML data in a document, the data is named a custom XML part.

You can create and modify custom XML parts in a document by using an application-level or document-level solution in Visual Studio. You do not need to start the Microsoft Office application to create and modify custom XML parts."

可见,我们是可以把任意内容的xml文件,塞到open xml excel中去,作为一个应用程序级别变量使用,类似web站点的Application变量。

第一步:创建下面这个xml文件或内存,里面只有一个ShowAlert变量:

<?xml version='1.0' encoding='UTF-8' ?>

<Root>

  <Extension1 ShowAlert='false' />

</Root>

第二步:将它load进入open xml excel中。

第三步:在自己的代码中查找已经解析并加载进来的xml内容,找到ShowAlert变量,这就达到目的了。

如果之后另存为excel文件,则open xml的目录结构如下,多了customXml目录,该目录里的item1.xml存放的就是刚才的xml内容。

这里没有贴上第二步,第三步的代码,以后再补吧!

 

推荐资料:

Standard ECMA-376 Office Open XML File Formatsedition (December 2006), 2nd edition (December 2008), 3rd edition (June 2011) and 4th edition (December 2012)

 

OFFICE OPEN XML OVERVIEW

 

Introducing the Office (2007) Open XML File Formats

Office Open XML, ECMA-376, and ISO/IEC 29500

What is the best way to store XML data in an Excel file

转载于:https://www.cnblogs.com/liuzhendong/p/3181241.html

你可能感兴趣的文章
Windows Phone开发(1):概论
查看>>
如何修改博客样式
查看>>
C#语法之泛型
查看>>
ArcGIS API for Silverlight中加载Google地形图(瓦片图)
查看>>
如何生成excel文件作为图像识别结果
查看>>
Liferay-Activiti 功能介绍 (新版Liferay7基本特性)
查看>>
Dom4j解析xml
查看>>
ubuntu 安装过程记录
查看>>
my blog zen :分享所学,backup一切~
查看>>
武侠-event
查看>>
学习C# delegate和C# event
查看>>
AD域的唯一ID字段uSNCreated
查看>>
Ubuntu 12.04中文输入法的安装
查看>>
jQuery的.live()和.die()[转]
查看>>
hdu_2002_计算球体积_解题报告
查看>>
连接数据库通过配置文件app.config
查看>>
赛星软件---智能视频分析事件检测
查看>>
【二叉树遍历】中序
查看>>
一个完整的类用来读取OpenSSL生成的pem格式的x509证书
查看>>
Delphi调用WebService(通过SoapHeader认证)经验总结
查看>>