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, “@”

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

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

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)
blank

相关推荐

  • matlab之simulink仿真入门

    matlab之simulink仿真入门MatlabSimulink仿真工具的应用****Simulink是一个用来对动态系统进行建模、仿真和分析的软件包。使用Simulink来建模、分析和仿真各种动态系统(包括连续系统、离散系统和混合系统),将是一件非常轻松的事情。它提供了一种图形化的交互环境,只需用鼠标拖动的方法便能迅速地建立起系统框图模型,甚至不需要编写一行代码。由于Simulink具有强大的功能与友好的用户界面,因此它已

  • “数加”斩获2017软博会金奖

    “数加”斩获2017软博会金奖

  • 排版系统Latex傻瓜方式使用(论文排版)

    排版系统Latex傻瓜方式使用(论文排版)

  • 华为太极magisk安装教程_教程:如何升级太极内部的应用

    华为太极magisk安装教程_教程:如何升级太极内部的应用使用过太极的小伙伴都知道,要把应用添加到太极(magisk版除外)中是个麻烦事儿:首先得花费大量的时间来创建应用,然后还必须卸载原来的应用,安装完毕之后又要花很长的时间来优化。如果待创建的应用安装包比较大并且你手机的CPU不在工作状态,那这个流程就不是一般的长了。这时候就有童鞋会问了,如果我在太极里面创建的应用要升级了怎么办?是不是每次升级都需要卸载原应用?实际上,在太极内部升级应用…

  • win10JDK环境变量的配置

    win10JDK环境变量的配置在win10系统下进行jdk环境变量与win7的一些区别,作者踩过一些坑,最后通过网上查找资料才将问题解决,但是网上的资料比较零碎,作者整理一下亲自操作过程并且将步骤详细的写了下来,希望能够帮助需要的人。一、下载安装完成jdk之后,桌面右键此电脑选择属性,进入以下界面,然后选择高级系统设置,进入系统配置二、进入系统配置之后点击环境变量,进入环境变量配置窗口三、此时我们可以看到有用户变量…

  • IOS版的MT4软件如何下载安装「建议收藏」

    IOS版的MT4软件如何下载安装「建议收藏」T4的版本总体来说还是比较全。包含了电脑版、安卓版/ios版,以及mac版。那么今天来重点讲解一下IOS版本的mt4如何下载。下载方式主要分以下2种:(1)在网页上获取安装包,通常mt4。yhtz。cc涵盖了多个版本的安装包,选择你需要的IOS即可下载到手机上后,然后就进入安装流程,点击下一步,下一步,总体来说,就是跟着安装提示走即可。(2)IOS属于手机版,IOS是可以在苹果应用商店下载的。下载流程就是:搜索Mt4,然后点击下载,一般会自动安装哦,就跟下载其他的客户端是一样的。下载安装好后

发表回复

您的电子邮箱地址不会被公开。

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