Excel种的数据类型研究【原创】【精】
因为要做一个项目,开始研究Excel种的数据类型。发现偌大的一个cnblogs竟然没人写这个,自己研究以后记录下来。
在我们通常的认识中,Excel中的数据类型有这么几种
1、常规;2、数值;3、货币;4、会计专用;5、日期;6、时间;
7、百分比;8、分数;9、科学技术;10、文本;11、特殊;12、自定义
同样在一个格子里边输入一个 6
如果什么都不设置,它是个【右对齐】的【常规】6
如果设置成文本,它是个【左对齐】的【文本】6
如果设置成货币,它是个【右对齐】的【货币】¥6:00
而你双击这个¥6.00,进入编辑状态,它显示的还就是个数字 6,编辑完了再自动展示成¥7.00
这其中一定有着某个原因。
学过“面向对象“的朋友应该已经敏锐地感觉出来了,对于这个单元格有个属性,专门记录用户对这个单元格的设置。
我尝试寻找,做了个测试用的EXCEL,每一列分别设置了不同的数据类型。
然后将这个excel文件读进C#程序中,
调试时可以发现这个属性
这是对于【1、常规格式的读取】,后来将剩下的东西有也都整理了出来
1、常规:"G/通用格式"
2、数值:"0.00_"
3、货币:"¥#,##0.00;¥-#,##0.00"
4、会计专用:"_ ¥* #,##0.00_ ;_ ¥* -#,##0.00_ ;_ ¥* \"-\"??_ ;_ @_ "
5、日期:"yyyy/m/d"
6、时间:"[$-F400]h:mm:ss AM/PM"
7、百分比:"0.00%"
8、分数:"# ?/?"
9、科学技术:"0.00E+00"
10、文本:"@"
11、特殊:"000000"
12、自定义:"G/通用格式"
这是个啥?
我在设置的时候,都没有进行详细的设置,数值都是默认值,但我不能保证用户在写这个Excel表的时候不对它进行详细设置啊!
那么,这是个啥?-------------是正则表达式!
我在每种类型中设置两个值,再把其中的每个选项试一试,
就能搞清楚这种类型的格式中的正则表达式怎么写!
但是,我很懒,
决定采用特征值的办法,正则就不写了,万一写的不周全呢。
那么,特征值是啥样的
1、常规:"G/通用格式" -------------- =="G/通用格式"
2、数值:"0.00_" -------------- endWith("_")
3、货币:"¥#,##0.00;¥-#,##0.00" -------------- startWith("¥")
4、会计专用:"_ ¥* #,##0.00_ ;_ ¥* -#,##0.00_ ;_ ¥* \"-\"??_ ;_ @_ " -------------startWith(“_ ¥”)
5、日期:"yyyy/m/d"-----------不知道怎么弄
6、时间:"[$-F400]h:mm:ss AM/PM" -------------- endWith("AM/PM")
7、百分比:"0.00%" -------------- endWith("%")
8、分数:"# ?/?" -------------- StartWith("#")
9、科学记数:"0.00E+00" -------------- contains("G/通用格式")
10、文本:"@" -------------- ==“@”
11、特殊:"000000" -------------- ==“000000”
12、自定义:"G/通用格式" -------------- =="G/通用格式"
无奈之下,我把日期格式的子选项都选了一遍,做了这么个表
这个条件麻烦了 ( endWith(“@”)|| endWith(“yyyy”)||endWith(“/d”) )&&length>3
就这样凑合交差吧,以后(没有以后)再去把它丰富了,做成牛逼的正则表达式。
Excel种的数据类型研究【原创】【精】的更多相关文章
- java 8种基本数据类型的默认值及所占字节数
通过一段代码来测试一下 8种基本数据类型的默认值 package dierge; public class Ceshi { int a; double b; boolean c; char d; fl ...
- 【转】Java八种基本数据类型的比较及其相互转化
java中有且仅有八种基本数据类型,记住就行,共分为四类: 第一类:整型-->byte short int long 第二类:浮点-->float doub ...
- main方法中声明8种基本数据类型的变量并赋值
main方法中声明8种基本数据类型的变量并赋值 char→ int→ long→ float→ double byte→ short→
- JavaSE复习日记 : 八种基本数据类型
/* * 基本数据类型 * * Java里的8种基本数据类型: * byte --- 1 byte = 8 bit; * short --- 2 byte = 16 bit; * int --- 4 ...
- js数据类型:引用和5种基本数据类型
javascript有2种基本数据类型:引用和基本数据类型 基本数据类型又有5个分类:布尔型.字符串.数值.undefined.NULL.
- Java常用类之【八种基本数据类型】
一.装箱和拆箱 装箱:将基本数据类型包装为对应的包装类对象 拆箱:将包装类对象转换成对应的基本数据类型 JDK5.0中为基本数据类型提供了自动装箱(boxing).拆箱(unboxing)功能 二.八 ...
- 【JavaScript的五种基本数据类型及转换】
js中有六种数据类型,包括五种基本数据类型(Number,String,Boolean,Null,Undefined),和一种混合数据类型就是特殊的(Object). "undefined& ...
- java中八种基本数据类型以及它们的封装类,String类型的一些理解
在我们面试或者考试过程中经常会考到八种基本数据类型以及它们的封装类,那么有哪八种基本数据类型呢?它们的封装类又是什么呢? 首先,八种基本数据类型分别是:int.short.float.double.l ...
- JAVA四类八种基本数据类型
boolean类型 Boolean在内存中占用一个字节. 当java编译器把java源代码编译为字节码时,会用int或byte来表示boolean.在java虚拟机中,用整数零来表示false,用任意 ...
随机推荐
- robotframework 接口测试 +RSA 加密
首先,实现RSA加密,需要用到pycrypto这个库,这个库又依赖openssl,所以需要先下载openssl,具体教程可以参考http://bbs.csdn.net/topics/392193545 ...
- 记一次排查mysql数据库连接未关闭问题的过程
在一些项目中由于一些特殊原因仍然保留着显示的获取数据库连接(Connection).提交事务.回滚事务.关闭连接等操作:其中关闭连接是比较容易疏忽又比较难在前期发现的问题. 我是如何排查连接未关闭的问 ...
- JavaScript异步与Promise基本用法(resolve与reject)
Promise解决的问题相信每个前端都遇到过这样一个问题,当一个异步任务的执行需要依赖另一个异步任务的结果时,我们一般会将两个异步任务嵌套起来,这种情况发生一两次还可以忍,但是发生很多次之后,就形成了 ...
- 前端面试经典题之apply与call的比较
在讲apply和call之前,我们需要先清楚在js中,this指向的是什么. 大家可以参考一下阮一峰老师写的关于JavaScript中this的原理讲解文章:http://www.ruanyifeng ...
- Windows Server 2019 配置远程桌面授权服务器许可RD
Windows Server 2019 配置远程桌面授权服务器许可RD Windows Server 201默认的最大远程登录连接为2个,超过这个数目需要使用license server进行授权,但又 ...
- Transformer详解
0 简述 Transformer改进了RNN最被人诟病的训练慢的缺点,利用self-attention机制实现快速并行. 并且Transformer可以增加到非常深的深度,充分发掘DNN模型的特性,提 ...
- Python全栈开发之5、模块
一.模块 1.import导入模块 #1.定义 模块:用来从逻辑上组织python代码(变量,函数,类,逻辑),本质就是.py结尾的python文件,实现一个功能 包:python package 用 ...
- POJ3450最长公共子串【kmp】
题目链接:http://poj.org/problem?id=3450 题目大意:给定n个长度不超过200的字符串,n < 4000.求这些字符串的最长公共子串,若没有,则输出 “IDENTIT ...
- Capacity To Ship Packages Within D Days
A conveyor belt has packages that must be shipped from one port to another within D days. The i-th p ...
- 【0.4】mysql版本特性(5.6-8.0)【转】
转自:http://blog.itpub.net/15498/viewspace-2650661/ MySQL 5.6 1).支持GTID复制 2).支持无损复制 3).支持延迟复制 4).支持基于库 ...