首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

小课堂 | POI读取科学记数法字段不准确?问题复现、尝试和解决

上周,有一个简单的跑批任务,跑批之前对文件进行了解析和比对,发现针对科学记数法表示的统一社会信用代码,POI读取出来后与原值不一致。 本文记录一下问题复现、所做尝试、问题解决以及如何防止。...问题重现 原始数据 具体内容如下: 问题重现 读取含有科学记数法的Excel文件,重现问题。...思考 针对涉及诸如身份证号、社会信用统一代码等长字段的Excel导入,读取时需要较为小心,如遇到纯数字的场景,会采用科学记数法记录,POI读取的时候可能不准确。...在上述的测试中,貌似纯数字长度大于11位的时候会转换成科学记数法。...我们可以增加一层校验,如读取的内容是数字类型,且使用了科学记数法,可以提示一下,如“xxx包含科学记数法,请转换成文本格式再进行导入”。

816110

关于SQL Server中将数值类型转换为字符串的问题

有些时候我们需要将这些数值类型转换为字符串类型,用到的转换函数就是cast和convert,这两个函数的作用都是进行类型转换,只不过语法格式不同。...declare @i float set @i=123456789 print 'test:'+convert(varchar(20),@i) 输出结果:test:1.23457e+008 输出的结果是使用科学计数法来表示的...,再看看可否通过指定转换样式来指定不使用科学计数法呢?...帮助文档中说到float 或 real 转换为字符数据时的 style 值: 0(默认值)最大为 6 位数。根据需要使用科学记数法。 1 始终为 8 位值。始终使用科学记数法。...始终使用科学记数法。 我们的值是123456789,超过了6位数.所以不管是0还是1,2结果都会使用科学计数法来表示。那么要怎么样才能将我们的数据不转换成科学计数法而输出呢?

2.4K10
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    JavaScript中科学计数法的问题

    值是对的,只是用了科学计数法,也是数值类型。但是问题来了,一般用户用户看不懂 2.2e-7,那么就把它转换成 0.00000022 吧。...(10) // "14010000000" 小于1且小数点后面带有6个0以上的浮点数值自动转化为科学计数法,要想转换成直观的数字表示就没那么容易了,我尝试了几种办法: JavaScript 代码: ""...所以索性就改进了一下: JavaScript 代码: function toNumberStr(num,digits) { // 正则匹配小数科学记数法 if (/^(\d+(?:\.\d+)?)...toNonExponential(1.401e10) // "14010000000" toNonExponential(0.0004) // "0.0004" 解析一下: 用.toExponential()将数字转化为科学记数法表示...e([+-]\d+)/,获取科学记数法中小数点后的字符及幂指数(e 后面的值),这样可以确定数字是几位小数。再用toFixed()转换成数值表示。

    12.4K61

    关于 IEEE 754 浮点数一些设计细节的疑问解释

    我们知道浮点数在内存中的表示,其实就是二进制的科学记数法。...0.365 * 10^5 => 3.65 * 10^4 二进制的科学记数法也是一样的,我们为了高效简介的表达,也像十进制的科学记数法一样,规定有效数字的整数部分不能是 0(因为前导 0 是无效数字...也就是说,例如 111010 它的二进制科学记数法是 1.11010 * 2^5 而不是 0.111010 * 2^6,因为这种表示不是最高效简介的表示方法 但是专家们很快发现:既然都规定了科学记数法有效数字的整数部分不能是...例如 1.11010 * 2^5,已知二进制科学记数法有效数字必然是 1....对于浮点数,我们进行大小比较的时候,其实就是比较两个科学记数法表示的数字,所以第一步肯定是先比较他们的数量级。

    1.6K20

    C++003-C++变量和数据类型2

    有效小数位也多 double z=1.1234567; cout<<x<<endl; cout<<y<<endl; cout<<z<<endl; // 前两个数采用了科学记数法...cout<<"$$$$$$$$$$$$$$$"<<endl; return 0; } 输出为: 1.23457e+07 5.678e-05 1.12346 $ 前两个数采用了科学记数法...浮点数用默认记数法defaultfloat编写:这种表示方法尽可能用多的位数,这个位数包括小数点前及小数点后的位数。...默认记数法特点 1)保留有效位至多6位(有效位包括小数点前的位数,正如上文译文提到的),如 double z=1.1234567;的输出为1.12346。...截取数字的规则是四舍五入 2)删去无效位数(也算是第一点的进一步说明) double x=1.234596; cout<<x<<endl; 的输出为1.2346,而不是1.23460 3)适当情况下会用科学记数法

    32950

    【C语言】数据类型存储、原码,反码,补码

    原因在于,使用补码,可以将符号位和数值域进行统一的处理;同时,加法和减法当中用补码也可以进行统一的处理(CPU当中只有加法器),此外,尤其是补码与原码的运算过程是可以进行相互转换的!...那么我着重的跟大家说说这个加法器吧,这个加法器其实就是当中CPU运用的加法运算,好接下来我给大家举个例子比如说:1 - 1 那你要转换成加法器怎么办呢?...记数法实例: 第1列是一般记数法; 第2列是科学记数法; 第3列是指数记数法(或称为e记数法); 这是科学记数法在计算机中的写法,e后面的数字代表10的指数; 接下来给大家看一个代码: #include...0001  如下实例:浮点数0.5     0.5     0.1 — 注意:这个是二进制当中的 -1 对于小数点来说后面的第一位数,是2的负一次方就是0.5     1.0 *  2 ^ -1 —— 转换成科学计数法...0000 0000 0000 0000 0000 ——这里E的存储是129,E的值还是129-127=2,如果你是double的数字那么这里要减去1023才能的到真实的E的值 0x40B00000 —— 转换出来的二进制转换十六进制数字

    57730

    人人都能懂的go语言教程——字符串篇

    函数的返回值有两个,第一个是类型转换之后的结果,第二个是一个error,也就是异常类型,表示在转换的过程当中是否有出现异常。如果没有异常,那么这个值会是一个nil。...相比于ParseInt它要简单一些, 只需要传入字符串即可,它默认按照10进制进行转换,并且转换之后会返回int类型的整数。...因为浮点数可以用多种方式来表示,比如科学记数法或者是十进制指数法等等。golang当中支持了这些格式,所以允许我们通过传入参数来指定我们希望得到的字符串的格式。...'f' 表示普通模式:(-ddd.dddd) 'b' 表示指数为二进制:(-ddddp±ddd) 'e' 表示十进制指数,也就是科学记数法的模式:(-d.dddde±dd) 'E' 和'e'一样,都是科学记数法的模式...字符串和bool型转换 除了常用的整数和浮点数之外,strconv还支持与bool类型进行转换。

    71820

    聊聊计算机的数字表示方法(下)

    按照百度百科的定义,移码是符号位取反的补码,我认为这样不好理解,很容易给人造成误解认为移码必须在补码的基础上进行计算的,其实移码就是对负数加上一个常数 2^(n-1),把这个负数本身转换为一个正数,再以正数编码...浮点数由“符号”、“指数”和“尾数”3部分构成,其表达式如下: 数值 =(符号)尾数 ×底数^指数; 我们可以简单粗暴的理解浮点数与定点数相比,浮点数是指一个数的小数点的位置不是固定的而是可以浮动的,是利用科学计数法来表达的实数...指数为什么使用移码而不是补码 还记得我们学习科学记数法时,两个使用科学记数法表示的数字进行计算,第一步就是对阶,即比较两个数指数的大小,如果不相等则通过移动指数较小数字的小数点位置使两个数的指数相等,然后再对小数部分进行加减计算...我们把0.4转换为2进制来看看: 0.42=0.8 取0 0.82=1.6 取1 0.62=1.2 取1 0.22=0.4 取0 0.42=0.8 取0 0.82...=1.6 取1 …… 由于只能保存4位尾数,则规格化后表示为1.10012^(-2); 我们再把1.10012^(-2)转换为10进制小数: 02^(-1)+12^(-2)+12^(-3)+02

    1.4K40

    Python-科学计算-pandas-14-df按行按列进行转换

    7 语言版本:Anaconda3-4.3.0.1-Windows-x86_64 编辑器:pycharm-community-2016.3.2 pandas:0.19.2 这个系列讲讲Python的科学计算及可视化...今天讲讲pandas模块 将Df按行按列进行转换 Part 1:目标 最近在网站开发过程中,需要将后端的Df数据,渲染到前端的Datatables,前端识别的数据格式有以下特征 - 数据格式为一个列表...- 列表中每一个元素为一个字典,每个字典对应前端表格的一行 - 单个字典的键为前端表格的列名,字典的值为前端表格每列取的值 简单来说就是要将一个Df转换为一个列表,该列表有特定的格式,如下示例 Df...格式转换为列表 ?...,那么是否可以按列进行转换呢?

    1.9K30
    领券