Excel2007格式分析和XML解析

1.    excel2007是使用xml格式来存储的,把一个excel文件后缀改为.zip,打开之后就直接可以看到一个excel文件对应的xml格式的文件了。

这里面有几部分



 



 

对于docProps目录下  这里core是文件的创建时间和修改时间,标题,主题和作者,app是文档的其他属性,文档类型,版本,是否只读,是否共享,安全属性等文档属性信息。


 2.在xl目录下是文档的具体内容信息

 

 

先看workbook.xml

workbook.xml文件包含一对<sheets>标签,其中的每个<sheet>元素都代表Excel 2007文件中的一个,工作表的名称就是其name属性的值,这里有三个sheet。

xl/_rels/workbook.xml.rels定义每个sheetid对应的sheet内容文件sheet1.xml,共享的单元格内容文件sharedstring.xml,样式文件style.xml是当前单元格的样式字体,颜色等样式的xml配置。

Theme存放的是当前的设置导航栏的默认样式。这两个看看大概也就能明白。

关键我们看看下面每个sheet的内容格式,

 

 

打开一个sheet1.xml看看

 
 
 我们找到对应的第一行第一列的值索引为2对应到sharedStrings.xml里面的index的值,这里si从0开始,第三个即为index为2的值,刚好跟我们的excel的A1值符合

而A1的s=9对应的样式style.xml我们也看看,找到cellXfs里面的第9个,不过这里又引用fontid字体样式,borderid样式,numfmtId格式等

 
 

最重要的是对于单元格的空值是没有v标签的,那么使用xml解析的时候就需要特别处理下,下面这个是官方示例程序,我做了修改,黄色部分是添加解析空单元格情况下座位默认空值添加到rowlist上,这样rowlist就完整了,不会因为一行空单元格就不往rowlist添加,造成无法判断是哪列为空,也无法验证某些列非必填下的判断。(使用的是POI)

 

那么xml怎么解析如下这个空单元格呢

<c r="C1" s="10" />

 

下面private boolean cellNull; 这个就是添加来判断是否为空单元格的

 

转载于:https://www.cnblogs.com/tinytiny/p/3356900.html

"runtimeerror: cuda error: cublas_status_invalid_value when calling `cublassg` 是在调用 `cublassg` 函数时发生的 CUDA 错误,错误代码为 `cublas_status_invalid_value`。这个错误通常是由于输入参数的值无效导致的。 首先,要解决这个错误,我们需要确定导致错误的原因。一种可能性是输入参数超出了有效范围或具有无效的值。另一种可能性是输入参数的大小与函数预期的大小不匹配。 为了解决这个错误,我们可以采取以下步骤: 1. 检查输入参数的值是否满足函数的要求。查看函数文档以确定每个参数的有效值范围,并确保输入满足这些要求。 2. 检查输入参数的大小是否正确。确保输入参数的维度与函数期望的维度匹配。 3. 检查输入参数是否进行了正确的初始化。如果输入参数没有正确初始化,可能会导致无效的值。 另外,检查 CUDA 版本和驱动程序版本是否与函数兼容也很重要。某些 CUDA 函数需要特定的驱动程序版本才能正常工作。 最后,如果以上方法无法解决问题,可以尝试在 CUDA 环境中调试并查找错误的根本原因。使用调试工具来检查内核的执行方式,并查看可能出现的错误。 总之,`runtimeerror: cuda error: cublas_status_invalid_value when calling `cublassg` 是一个 CUDA 错误,表示在调用 `cublassg` 函数时发生了值无效的情况。通过检查输入参数的值、大小和初始化情况,以及检查 CUDA 和驱动程序的兼容性,可以解决这个问题。如果问题仍然存在,可以使用调试工具来进一步分析和解决错误。"
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值