OOXML,XLSX分析

OOXML,XLSX分析07以上的xlsx是使用了OOXML和zip,将后缀修改为.zip,就可以看到文件,主要分析xl目录下的文件,如图:主要数据文件在xl目录下面styles.xml里面存放着excel的样式数据很

大家好,又见面了,我是你们的朋友全栈君。

07以上的xlsx是使用了OOXML和zip,将后缀修改为.zip,就可以看到文件,主要分析xl目录下的文件,如图:

 <span role="heading" aria-level="2">OOXML,XLSX分析

主要数据文件在xl目录下面

<span role="heading" aria-level="2">OOXML,XLSX分析

styles.xml里面存放着excel的样式数据

<span role="heading" aria-level="2">OOXML,XLSX分析

很容易看出包含,字体,边框,单元格样式信息。

sharedStrings.xml存储的excel中的字符串,excel中的字符串都是放在这个里面,共享字符串,所以往往excel的文件会比txt小。

worksheets里面是excel的sheet文件

<span role="heading" aria-level="2">OOXML,XLSX分析

打开xml

<span role="heading" aria-level="2">OOXML,XLSX分析

 

其中r=”C2″表示excel的C2这个单元格,t=”s”表示该单元格是字符串,val是2表示在sharedStrings.xml里面第二个共享的字符串。

其中r=”N2″表示excel的N2这个单元格,s=”2″表示该单元格有样式,在styles.xml里面的cellXfs里面的第3个样式(0是第一个)。

仔细分析cellXfs会发现<xf borderId=”0″ fillId=”0″ fontId=”0″ numFmtId=”0″ xfId=”0″/>里面有numFmtId,表示数字的格式,每个数字代表不同的样式,看POI的源码org.apache.poi.ss.usermodel.BuiltinFormats里面能找到每个数字代表的含义:

0, “General”

1, “0”

2, “0.00”

3, “#,##0”

4, “#,##0.00”

5, “$#,##0_);($#,##0)”

6, “$#,##0_);[Red]($#,##0)”

7, “$#,##0.00);($#,##0.00)”

8, “$#,##0.00_);[Red]($#,##0.00)”

9, “0%”

0xa, “0.00%”

0xb, “0.00E+00”

0xc, “# ?/?”

0xd, “# ??/??”

0xe, “m/d/yy”

0xf, “d-mmm-yy”

0x10, “d-mmm”

0x11, “mmm-yy”

0x12, “h:mm AM/PM”

0x13, “h:mm:ss AM/PM”

0x14, “h:mm”

0x15, “h:mm:ss”

0x16, “m/d/yy h:mm”

// 0x17 – 0x24 reserved for international and undocumented

0x25, “#,##0_);(#,##0)”

0x26, “#,##0_);[Red](#,##0)”

0x27, “#,##0.00_);(#,##0.00)”

0x28, “#,##0.00_);[Red](#,##0.00)”

0x29, “_(* #,##0_);_(* (#,##0);_(* \”-\”_);_(@_)”

0x2a, “_($* #,##0_);_($* (#,##0);_($* \”-\”_);_(@_)”

0x2b, “_(* #,##0.00_);_(* (#,##0.00);_(* \”-\”??_);_(@_)”

0x2c, “_($* #,##0.00_);_($* (#,##0.00);_($* \”-\”??_);_(@_)”

0x2d, “mm:ss”

0x2e, “[h]:mm:ss”

0x2f, “mm:ss.0”

0x30, “##0.0E+0”

0x31, “@”

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/154564.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 快速排序(过程图解)

     假设我们现在对“6  1  27  9  3  4  510  8”这个10个数进行排序。首先在这个序列中随便找一个数作为基准数(不要被这个名词吓到了,就是一个用来参照的数,待会你就知道它用来做啥的了)。为了方便,就让第一个数6作为基准数吧。接下来,需要将这个序列中所有比基准数大的数放在6的右边,比基准数小的数放在6的左边,类似下面这种排列。    3  1  25  4  …

    2022年4月5日
    240
  • 简单高效,分享几款我在使用的效率神器[通俗易懂]

    做一个积极的人编码、改bug、提升自己我有一个乐园,面向编程,春暖花开!今天周六了,分享几款我目前在用的小工具,希望对你有用。使用工具的好处等等,我就不过多介绍了,下面文章的内容是先简单介绍这几款工具,然后说明一下我是怎么应用的。简单的一个思维导图,看下本文全貌:文章目录神器介绍1、火柴-效率神器2、ALTRun – 快速启动3、Typora – Markdown 编辑器4、Snip…

    2022年2月28日
    105
  • phpstorm激活码2021年4月_通用破解码

    phpstorm激活码2021年4月_通用破解码,https://javaforall.net/100143.html。详细ieda激活码不妨到全栈程序员必看教程网一起来了解一下吧!

    2022年3月16日
    93
  • wpf之StackPanel、WrapPanel、WrapPanel之间的关系

    wpf之StackPanel、WrapPanel、WrapPanel之间的关系一、StackPanelStackPanel是以堆叠的方式显示其中的控件1、可以使用Orientation属性更改堆叠的顺序分为水平方向(Orientation=”Horizontal”)和竖直方向(Orientation=”Vertical”),以保证要实现的效果。二、WrapPanel以流的形式由左到右,由上到下显示控件,其功能类似于JavaAWT布局中的FlowLayout…

    2022年7月22日
    20
  • Spring中bean的作用域与生命周期

    Spring中bean的作用域与生命周期在Spring中,那些组成应用程序的主体及由SpringIoC容器所管理的对象,被称之为bean。简单地讲,bean就是由IoC容器初始化、装配及管理的对象,除此之外,bean就与应用程序中的其他对象没有什么区别了。而bean的定义以及bean相互间的依赖关系将通过配置元数据来描述。  Spring中的bean默认都是单例的,这些单例Bean在多线程程序下如何保证线程安全呢?例如对于Web应用来

    2022年4月30日
    58
  • gridbagconstraints什么意思_gridlayout四个参数

    gridbagconstraints什么意思_gridlayout四个参数gridx,gridy:相对于容器左上角的x,y坐标gridwidth,gridheight:设置组件横向与纵向的单元格跨越个数。weightx,weighty:是否拉伸(0不拉伸,1拉伸)insets:设置元素的位置,类似html的margin,只是顺序有点不一样,依次是上,左,下,右。java.awt.Insets.Insets(inttop,intleft,intbottom,intright)fill:当某个组件未能填满单元格..

    2022年9月9日
    2

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号