Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
苏木力格
easyexcel
提交
995a96f1
E
easyexcel
项目概览
苏木力格
/
easyexcel
与 Fork 源项目一致
从无法访问的项目Fork
通知
7
Star
0
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
E
easyexcel
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
体验新版 GitCode,发现更多精彩内容 >>
提交
995a96f1
编写于
5月 08, 2021
作者:
是
是仪
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
修复读取的时候用string接收数字 可能四舍五入不一致的bug
上级
cebc5217
变更
9
隐藏空白更改
内联
并排
Showing
9 changed file
with
30 addition
and
14 deletion
+30
-14
pom.xml
pom.xml
+1
-1
src/main/java/com/alibaba/excel/converters/string/StringNumberConverter.java
...libaba/excel/converters/string/StringNumberConverter.java
+1
-1
src/main/java/com/alibaba/excel/metadata/format/DataFormatter.java
...java/com/alibaba/excel/metadata/format/DataFormatter.java
+4
-4
src/main/java/com/alibaba/excel/util/NumberDataFormatterUtils.java
...java/com/alibaba/excel/util/NumberDataFormatterUtils.java
+3
-1
src/test/java/com/alibaba/easyexcel/test/core/encrypt/EncryptDataTest.java
.../alibaba/easyexcel/test/core/encrypt/EncryptDataTest.java
+17
-6
src/test/java/com/alibaba/easyexcel/test/temp/Lock2Test.java
src/test/java/com/alibaba/easyexcel/test/temp/Lock2Test.java
+1
-1
src/test/resources/dataformat/dataformat.xls
src/test/resources/dataformat/dataformat.xls
+0
-0
src/test/resources/dataformat/dataformat.xlsx
src/test/resources/dataformat/dataformat.xlsx
+0
-0
update.md
update.md
+3
-0
未找到文件。
pom.xml
浏览文件 @
995a96f1
...
...
@@ -4,7 +4,7 @@
<modelVersion>
4.0.0
</modelVersion>
<groupId>
com.alibaba
</groupId>
<artifactId>
easyexcel
</artifactId>
<version>
2.2.
8
</version>
<version>
2.2.
9
</version>
<packaging>
jar
</packaging>
<name>
easyexcel
</name>
...
...
src/main/java/com/alibaba/excel/converters/string/StringNumberConverter.java
浏览文件 @
995a96f1
...
...
@@ -47,7 +47,7 @@ public class StringNumberConverter implements Converter<String> {
}
// Excel defines formatting
if
(
cellData
.
getDataFormat
()
!=
null
&&
!
StringUtils
.
isEmpty
(
cellData
.
getDataFormatString
()))
{
return
NumberDataFormatterUtils
.
format
(
cellData
.
getNumberValue
()
.
doubleValue
()
,
cellData
.
getDataFormat
(),
return
NumberDataFormatterUtils
.
format
(
cellData
.
getNumberValue
(),
cellData
.
getDataFormat
(),
cellData
.
getDataFormatString
(),
globalConfiguration
);
}
// Default conversion number
...
...
src/main/java/com/alibaba/excel/metadata/format/DataFormatter.java
浏览文件 @
995a96f1
...
...
@@ -630,8 +630,8 @@ public class DataFormatter {
* @param dataFormatString
* @return a formatted number string
*/
private
String
getFormattedNumberString
(
Double
data
,
Integer
dataFormat
,
String
dataFormatString
)
{
Format
numberFormat
=
getFormat
(
data
,
dataFormat
,
dataFormatString
);
private
String
getFormattedNumberString
(
BigDecimal
data
,
Integer
dataFormat
,
String
dataFormatString
)
{
Format
numberFormat
=
getFormat
(
data
.
doubleValue
()
,
dataFormat
,
dataFormatString
);
String
formatted
=
numberFormat
.
format
(
data
);
return
formatted
.
replaceFirst
(
"E(\\d)"
,
"E+$1"
);
// to match Excel's E-notation
}
...
...
@@ -644,9 +644,9 @@ public class DataFormatter {
* @param dataFormatString
* @return
*/
public
String
format
(
Double
data
,
Integer
dataFormat
,
String
dataFormatString
)
{
public
String
format
(
BigDecimal
data
,
Integer
dataFormat
,
String
dataFormatString
)
{
if
(
DateUtils
.
isADateFormat
(
dataFormat
,
dataFormatString
))
{
return
getFormattedDateString
(
data
,
dataFormat
,
dataFormatString
);
return
getFormattedDateString
(
data
.
doubleValue
()
,
dataFormat
,
dataFormatString
);
}
return
getFormattedNumberString
(
data
,
dataFormat
,
dataFormatString
);
}
...
...
src/main/java/com/alibaba/excel/util/NumberDataFormatterUtils.java
浏览文件 @
995a96f1
package
com.alibaba.excel.util
;
import
java.math.BigDecimal
;
import
com.alibaba.excel.metadata.format.DataFormatter
;
import
com.alibaba.excel.metadata.GlobalConfiguration
;
...
...
@@ -24,7 +26,7 @@ public class NumberDataFormatterUtils {
* @param globalConfiguration
* @return
*/
public
static
String
format
(
Double
data
,
Integer
dataFormat
,
String
dataFormatString
,
public
static
String
format
(
BigDecimal
data
,
Integer
dataFormat
,
String
dataFormatString
,
GlobalConfiguration
globalConfiguration
)
{
DataFormatter
dataFormatter
=
DATA_FORMATTER_THREAD_LOCAL
.
get
();
if
(
dataFormatter
==
null
)
{
...
...
src/test/java/com/alibaba/easyexcel/test/core/encrypt/EncryptDataTest.java
浏览文件 @
995a96f1
...
...
@@ -3,21 +3,23 @@ package com.alibaba.easyexcel.test.core.encrypt;
import
java.io.File
;
import
java.io.FileInputStream
;
import
java.io.FileOutputStream
;
import
java.math.BigDecimal
;
import
java.math.RoundingMode
;
import
java.text.DecimalFormat
;
import
java.util.ArrayList
;
import
java.util.List
;
import
org.junit.BeforeClass
;
import
org.junit.FixMethodOrder
;
import
org.junit.Test
;
import
org.junit.runners.MethodSorters
;
import
com.alibaba.easyexcel.test.core.simple.SimpleData
;
import
com.alibaba.easyexcel.test.util.TestFileUtil
;
import
com.alibaba.excel.EasyExcel
;
import
com.alibaba.excel.support.ExcelTypeEnum
;
import
org.junit.BeforeClass
;
import
org.junit.FixMethodOrder
;
import
org.junit.Test
;
import
org.junit.runners.MethodSorters
;
/**
*
* @author Jiaju Zhuang
*/
@FixMethodOrder
(
MethodSorters
.
NAME_ASCENDING
)
...
...
@@ -28,6 +30,15 @@ public class EncryptDataTest {
private
static
File
file07OutputStream
;
private
static
File
file03OutputStream
;
@Test
public
void
testformat
()
{
DecimalFormat
decimalFormat
=
new
DecimalFormat
(
"0.00"
);
decimalFormat
.
setRoundingMode
(
RoundingMode
.
HALF_UP
);
BigDecimal
bigDecimal
=
new
BigDecimal
(
"0.105"
);
System
.
out
.
println
(
decimalFormat
.
format
(
bigDecimal
));
}
@BeforeClass
public
static
void
init
()
{
file07
=
TestFileUtil
.
createNewFile
(
"encrypt07.xlsx"
);
...
...
src/test/java/com/alibaba/easyexcel/test/temp/Lock2Test.java
浏览文件 @
995a96f1
...
...
@@ -34,7 +34,7 @@ public class Lock2Test {
@Test
public
void
test
()
throws
Exception
{
// File file = TestFileUtil.readUserHomeFile("test/test6.xls");
File
file
=
new
File
(
"
D:\\test\\T85_税金入库表202010
.xlsx"
);
File
file
=
new
File
(
"
/Users/zhuangjiaju/Downloads/签到金模板-0507-v3
.xlsx"
);
List
<
Object
>
list
=
EasyExcel
.
read
(
file
).
sheet
(
0
).
headRowNumber
(
0
).
doReadSync
();
LOGGER
.
info
(
"数据:{}"
,
list
.
size
());
...
...
src/test/resources/dataformat/dataformat.xls
浏览文件 @
995a96f1
无法预览此类型文件
src/test/resources/dataformat/dataformat.xlsx
浏览文件 @
995a96f1
无法预览此类型文件
update.md
浏览文件 @
995a96f1
# 2.2.9
*
修复读取的时候用string接收数字 可能四舍五入不一致的bug
# 2.2.8
*
兼容07在特殊的excel的情况下,读取数据异常
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录