因为要做一个项目,开始研究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种的数据类型研究【原创】【精】的更多相关文章

  1. java 8种基本数据类型的默认值及所占字节数

    通过一段代码来测试一下 8种基本数据类型的默认值 package dierge; public class Ceshi { int a; double b; boolean c; char d; fl ...

  2. 【转】Java八种基本数据类型的比较及其相互转化

    java中有且仅有八种基本数据类型,记住就行,共分为四类: 第一类:整型-->byte     short      int     long 第二类:浮点-->float    doub ...

  3. main方法中声明8种基本数据类型的变量并赋值

    main方法中声明8种基本数据类型的变量并赋值  char→  int→ long→ float→ double byte→ short→ 

  4. JavaSE复习日记 : 八种基本数据类型

    /* * 基本数据类型 * * Java里的8种基本数据类型: * byte --- 1 byte = 8 bit; * short --- 2 byte = 16 bit; * int --- 4 ...

  5. js数据类型:引用和5种基本数据类型

    javascript有2种基本数据类型:引用和基本数据类型 基本数据类型又有5个分类:布尔型.字符串.数值.undefined.NULL.

  6. Java常用类之【八种基本数据类型】

    一.装箱和拆箱 装箱:将基本数据类型包装为对应的包装类对象 拆箱:将包装类对象转换成对应的基本数据类型 JDK5.0中为基本数据类型提供了自动装箱(boxing).拆箱(unboxing)功能 二.八 ...

  7. 【JavaScript的五种基本数据类型及转换】

    js中有六种数据类型,包括五种基本数据类型(Number,String,Boolean,Null,Undefined),和一种混合数据类型就是特殊的(Object). "undefined& ...

  8. java中八种基本数据类型以及它们的封装类,String类型的一些理解

    在我们面试或者考试过程中经常会考到八种基本数据类型以及它们的封装类,那么有哪八种基本数据类型呢?它们的封装类又是什么呢? 首先,八种基本数据类型分别是:int.short.float.double.l ...

  9. JAVA四类八种基本数据类型

    boolean类型 Boolean在内存中占用一个字节. 当java编译器把java源代码编译为字节码时,会用int或byte来表示boolean.在java虚拟机中,用整数零来表示false,用任意 ...

随机推荐

  1. Jmeter启动报错解决方案

    安装好jmeter之后在启动Jmeter的过程中出现了如下的报错信息(大部分的原因是配置不对): /usr/local/Cellar/jmeter/5.1.1/libexec/bin/jmeter: ...

  2. 关于Java新手开发配置各种环境可能会遇到的的坑

    一.软件的安装 虽然国内的软件都支持中文目录安装,部分国外软件也支持,但是作为一名合格的程序开发者,必须做到以下几点 Windows下开发软件的安装目录和环境变量中永远不要包含中文字符,包括汉字[]. ...

  3. Golang语言细节小结

    前段时间,看了菜鸟入门,较浅的认识一下golang的语法习惯和规则,然后跟别人做了个爬虫项目,但是对于golang语言的语法结构还不是很懂.又看了遍<go实战>第二章. 构建程序在构建可执 ...

  4. Spring自定义参数解析器

    结合redis编写User自定义参数解析器UserArgumentResolver import javax.servlet.http.Cookie; import javax.servlet.htt ...

  5. 石子合并2——区间DP【洛谷P1880题解】

    [区间dp让人头痛……还是要多写些题目练手,抽空写篇博客总结一下] 这题区间dp入门题,理解区间dp或者练手都很妙 ——题目链接—— (或者直接看下面) 题面 在一个圆形操场的四周摆放N堆石子,现要将 ...

  6. 今天遇到了不能创建mysql函数

    今天用navicat 不能创建函数,查询了 MySQL函数不能创建,是未开启功能: mysql> show variables like '%func%'; +----------------- ...

  7. 小米soar

    SOAR 简介 SOAR,即 SQL Optimizer And Rewriter,是一款 SQL 智能优化与改写工具,由小米运维 DBA 团队出品 SOAR 体系架构 SOAR主要由语法解析器,集成 ...

  8. 华为设备ACL与NAT技术

    ACL 访问控制列表(Access Control Lists),是应用在路由器(或三层交换机)接口上的指令列表,用来告诉路由器哪些数据可以接收,哪些数据是需要被拒绝的,ACL的定义是基于协议的,它适 ...

  9. ZROI-Day2比赛解题报告

    ZROIDay2-比赛解题报告 版权原因不提供题面信息 序 这几天作息有点鬼畜,虽然昨晚很晚睡但是早上精神还不错,看到题发现T1很友好?T2woc这暴力都好难打?T3多项式?!这样下去比赛会不会出现更 ...

  10. wpf 模板绑定父对象

    有两种方式可以实现在模板中元素绑定到父对象 1.<ContentPresenter Margin=”{TemplateBinding Padding}”/> 2.Color=”{Bindi ...