Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
苏木力格
easyexcel
提交
9b3c8f12
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,发现更多精彩内容 >>
提交
9b3c8f12
编写于
7月 16, 2019
作者:
Z
zhuangjiaju
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
加入默认转换器
上级
058df4d7
变更
17
隐藏空白更改
内联
并排
Showing
17 changed file
with
391 addition
and
28 deletion
+391
-28
src/main/java/com/alibaba/excel/converters/bigdecimal/BigDecimalNumberConverter.java
...xcel/converters/bigdecimal/BigDecimalNumberConverter.java
+1
-1
src/main/java/com/alibaba/excel/converters/bigdecimal/BigDecimalStringConverter.java
...xcel/converters/bigdecimal/BigDecimalStringConverter.java
+2
-15
src/main/java/com/alibaba/excel/converters/byteconverter/ByteNumberConverter.java
...a/excel/converters/byteconverter/ByteNumberConverter.java
+1
-1
src/main/java/com/alibaba/excel/converters/byteconverter/ByteStringConverter.java
...a/excel/converters/byteconverter/ByteStringConverter.java
+2
-1
src/main/java/com/alibaba/excel/converters/doubleconverter/DoubleBooleanConverter.java
...el/converters/doubleconverter/DoubleBooleanConverter.java
+7
-7
src/main/java/com/alibaba/excel/converters/doubleconverter/DoubleNumberConverter.java
...cel/converters/doubleconverter/DoubleNumberConverter.java
+2
-2
src/main/java/com/alibaba/excel/converters/doubleconverter/DoubleStringConverter.java
...cel/converters/doubleconverter/DoubleStringConverter.java
+2
-1
src/main/java/com/alibaba/excel/converters/floatconverter/FloatBooleanConverter.java
...xcel/converters/floatconverter/FloatBooleanConverter.java
+43
-0
src/main/java/com/alibaba/excel/converters/floatconverter/FloatNumberConverter.java
...excel/converters/floatconverter/FloatNumberConverter.java
+35
-0
src/main/java/com/alibaba/excel/converters/floatconverter/FloatStringConverter.java
...excel/converters/floatconverter/FloatStringConverter.java
+35
-0
src/main/java/com/alibaba/excel/converters/integer/IntegerBooleanConverter.java
...aba/excel/converters/integer/IntegerBooleanConverter.java
+43
-0
src/main/java/com/alibaba/excel/converters/integer/IntegerNumberConverter.java
...baba/excel/converters/integer/IntegerNumberConverter.java
+35
-0
src/main/java/com/alibaba/excel/converters/integer/IntegerStringConverter.java
...baba/excel/converters/integer/IntegerStringConverter.java
+35
-0
src/main/java/com/alibaba/excel/converters/longconverter/IntegerBooleanConverter.java
...cel/converters/longconverter/IntegerBooleanConverter.java
+43
-0
src/main/java/com/alibaba/excel/converters/longconverter/LongNumberConverter.java
...a/excel/converters/longconverter/LongNumberConverter.java
+35
-0
src/main/java/com/alibaba/excel/converters/longconverter/LongStringConverter.java
...a/excel/converters/longconverter/LongStringConverter.java
+35
-0
src/main/java/com/alibaba/excel/util/NumberUtils.java
src/main/java/com/alibaba/excel/util/NumberUtils.java
+35
-0
未找到文件。
src/main/java/com/alibaba/excel/converters/bigdecimal/BigDecimalNumberConverter.java
浏览文件 @
9b3c8f12
...
...
@@ -26,7 +26,7 @@ public class BigDecimalNumberConverter implements Converter<BigDecimal> {
@Override
public
BigDecimal
convertToJavaData
(
CellData
cellData
,
ExcelContentProperty
contentProperty
)
{
return
new
BigDecimal
(
cellData
.
getDoubleValue
());
return
BigDecimal
.
valueOf
(
cellData
.
getDoubleValue
());
}
@Override
...
...
src/main/java/com/alibaba/excel/converters/bigdecimal/BigDecimalStringConverter.java
浏览文件 @
9b3c8f12
package
com.alibaba.excel.converters.bigdecimal
;
import
java.math.BigDecimal
;
import
java.math.RoundingMode
;
import
java.text.DecimalFormat
;
import
com.alibaba.excel.converters.Converter
;
import
com.alibaba.excel.enums.CellDataTypeEnum
;
import
com.alibaba.excel.metadata.CellData
;
import
com.alibaba.excel.metadata.property.ExcelContentProperty
;
import
com.alibaba.excel.util.
String
Utils
;
import
com.alibaba.excel.util.
Number
Utils
;
/**
* BigDecimal and string converter
...
...
@@ -34,17 +32,6 @@ public class BigDecimalStringConverter implements Converter<BigDecimal> {
@Override
public
CellData
convertToExcelData
(
BigDecimal
value
,
ExcelContentProperty
contentProperty
)
{
String
format
=
null
;
RoundingMode
roundingMode
=
RoundingMode
.
HALF_UP
;
if
(
contentProperty
.
getNumberFormatProperty
()
!=
null
)
{
format
=
contentProperty
.
getNumberFormatProperty
().
getFormat
();
roundingMode
=
contentProperty
.
getNumberFormatProperty
().
getRoundingMode
();
}
if
(
StringUtils
.
isEmpty
(
format
))
{
return
new
CellData
(
value
.
toString
());
}
DecimalFormat
decimalFormat
=
new
DecimalFormat
(
format
);
decimalFormat
.
setRoundingMode
(
roundingMode
);
return
new
CellData
(
decimalFormat
.
format
(
value
));
return
NumberUtils
.
formatToCellData
(
value
,
contentProperty
);
}
}
src/main/java/com/alibaba/excel/converters/byteconverter/ByteNumberConverter.java
浏览文件 @
9b3c8f12
...
...
@@ -29,7 +29,7 @@ public class ByteNumberConverter implements Converter<Byte> {
@Override
public
CellData
convertToExcelData
(
Byte
value
,
ExcelContentProperty
contentProperty
)
{
return
new
CellData
(
(
double
)
value
);
return
new
CellData
(
value
.
doubleValue
()
);
}
}
src/main/java/com/alibaba/excel/converters/byteconverter/ByteStringConverter.java
浏览文件 @
9b3c8f12
...
...
@@ -4,6 +4,7 @@ import com.alibaba.excel.converters.Converter;
import
com.alibaba.excel.enums.CellDataTypeEnum
;
import
com.alibaba.excel.metadata.CellData
;
import
com.alibaba.excel.metadata.property.ExcelContentProperty
;
import
com.alibaba.excel.util.NumberUtils
;
/**
* Byte and string converter
...
...
@@ -29,7 +30,7 @@ public class ByteStringConverter implements Converter<Byte> {
@Override
public
CellData
convertToExcelData
(
Byte
value
,
ExcelContentProperty
contentProperty
)
{
return
new
CellData
(
value
.
toString
()
);
return
NumberUtils
.
formatToCellData
(
value
,
contentProperty
);
}
}
src/main/java/com/alibaba/excel/converters/doubleconverter/
Byt
eBooleanConverter.java
→
src/main/java/com/alibaba/excel/converters/doubleconverter/
Doubl
eBooleanConverter.java
浏览文件 @
9b3c8f12
...
...
@@ -6,17 +6,17 @@ import com.alibaba.excel.metadata.CellData;
import
com.alibaba.excel.metadata.property.ExcelContentProperty
;
/**
*
Byt
e and boolean converter
*
Doubl
e and boolean converter
*
* @author zhuangjiaju
*/
public
class
ByteBooleanConverter
implements
Converter
<
Byt
e
>
{
private
static
final
Byte
ONE
=
(
byte
)
1
;
private
static
final
Byte
ZERO
=
(
byte
)
0
;
public
class
DoubleBooleanConverter
implements
Converter
<
Doubl
e
>
{
private
static
final
Double
ONE
=
1.0
;
private
static
final
Double
ZERO
=
0.
0
;
@Override
public
Class
supportJavaTypeKey
()
{
return
Byt
e
.
class
;
return
Doubl
e
.
class
;
}
@Override
...
...
@@ -25,7 +25,7 @@ public class ByteBooleanConverter implements Converter<Byte> {
}
@Override
public
Byt
e
convertToJavaData
(
CellData
cellData
,
ExcelContentProperty
contentProperty
)
{
public
Doubl
e
convertToJavaData
(
CellData
cellData
,
ExcelContentProperty
contentProperty
)
{
if
(
cellData
.
getBooleanValue
())
{
return
ONE
;
}
...
...
@@ -33,7 +33,7 @@ public class ByteBooleanConverter implements Converter<Byte> {
}
@Override
public
CellData
convertToExcelData
(
Byt
e
value
,
ExcelContentProperty
contentProperty
)
{
public
CellData
convertToExcelData
(
Doubl
e
value
,
ExcelContentProperty
contentProperty
)
{
if
(
ONE
.
equals
(
value
))
{
return
new
CellData
(
Boolean
.
TRUE
);
}
...
...
src/main/java/com/alibaba/excel/converters/doubleconverter/DoubleNumberConverter.java
浏览文件 @
9b3c8f12
...
...
@@ -23,12 +23,12 @@ public class DoubleNumberConverter implements Converter<Double> {
}
@Override
public
Double
convertToJavaData
(
CellData
cellData
,
ExcelContentProperty
contentProperty
)
throws
Exception
{
public
Double
convertToJavaData
(
CellData
cellData
,
ExcelContentProperty
contentProperty
)
{
return
cellData
.
getDoubleValue
();
}
@Override
public
CellData
convertToExcelData
(
Double
value
,
ExcelContentProperty
contentProperty
)
throws
Exception
{
public
CellData
convertToExcelData
(
Double
value
,
ExcelContentProperty
contentProperty
)
{
return
new
CellData
(
value
);
}
...
...
src/main/java/com/alibaba/excel/converters/doubleconverter/DoubleStringConverter.java
浏览文件 @
9b3c8f12
...
...
@@ -4,6 +4,7 @@ import com.alibaba.excel.converters.Converter;
import
com.alibaba.excel.enums.CellDataTypeEnum
;
import
com.alibaba.excel.metadata.CellData
;
import
com.alibaba.excel.metadata.property.ExcelContentProperty
;
import
com.alibaba.excel.util.NumberUtils
;
/**
* Double and string converter
...
...
@@ -29,6 +30,6 @@ public class DoubleStringConverter implements Converter<Double> {
@Override
public
CellData
convertToExcelData
(
Double
value
,
ExcelContentProperty
contentProperty
)
{
return
new
CellData
(
value
.
toString
()
);
return
NumberUtils
.
formatToCellData
(
value
,
contentProperty
);
}
}
src/main/java/com/alibaba/excel/converters/floatconverter/FloatBooleanConverter.java
0 → 100644
浏览文件 @
9b3c8f12
package
com.alibaba.excel.converters.floatconverter
;
import
com.alibaba.excel.converters.Converter
;
import
com.alibaba.excel.enums.CellDataTypeEnum
;
import
com.alibaba.excel.metadata.CellData
;
import
com.alibaba.excel.metadata.property.ExcelContentProperty
;
/**
* Float and boolean converter
*
* @author zhuangjiaju
*/
public
class
FloatBooleanConverter
implements
Converter
<
Float
>
{
private
static
final
Float
ONE
=
(
float
)
1.0
;
private
static
final
Float
ZERO
=
(
float
)
0.0
;
@Override
public
Class
supportJavaTypeKey
()
{
return
Float
.
class
;
}
@Override
public
CellDataTypeEnum
supportExcelTypeKey
()
{
return
CellDataTypeEnum
.
BOOLEAN
;
}
@Override
public
Float
convertToJavaData
(
CellData
cellData
,
ExcelContentProperty
contentProperty
)
{
if
(
cellData
.
getBooleanValue
())
{
return
ONE
;
}
return
ZERO
;
}
@Override
public
CellData
convertToExcelData
(
Float
value
,
ExcelContentProperty
contentProperty
)
{
if
(
ONE
.
equals
(
value
))
{
return
new
CellData
(
Boolean
.
TRUE
);
}
return
new
CellData
(
Boolean
.
FALSE
);
}
}
src/main/java/com/alibaba/excel/converters/floatconverter/FloatNumberConverter.java
0 → 100644
浏览文件 @
9b3c8f12
package
com.alibaba.excel.converters.floatconverter
;
import
com.alibaba.excel.converters.Converter
;
import
com.alibaba.excel.enums.CellDataTypeEnum
;
import
com.alibaba.excel.metadata.CellData
;
import
com.alibaba.excel.metadata.property.ExcelContentProperty
;
/**
* Float and number converter
*
* @author zhuangjiaju
*/
public
class
FloatNumberConverter
implements
Converter
<
Float
>
{
@Override
public
Class
supportJavaTypeKey
()
{
return
Float
.
class
;
}
@Override
public
CellDataTypeEnum
supportExcelTypeKey
()
{
return
CellDataTypeEnum
.
NUMBER
;
}
@Override
public
Float
convertToJavaData
(
CellData
cellData
,
ExcelContentProperty
contentProperty
)
{
return
cellData
.
getDoubleValue
().
floatValue
();
}
@Override
public
CellData
convertToExcelData
(
Float
value
,
ExcelContentProperty
contentProperty
)
{
return
new
CellData
(
value
.
doubleValue
());
}
}
src/main/java/com/alibaba/excel/converters/floatconverter/FloatStringConverter.java
0 → 100644
浏览文件 @
9b3c8f12
package
com.alibaba.excel.converters.floatconverter
;
import
com.alibaba.excel.converters.Converter
;
import
com.alibaba.excel.enums.CellDataTypeEnum
;
import
com.alibaba.excel.metadata.CellData
;
import
com.alibaba.excel.metadata.property.ExcelContentProperty
;
import
com.alibaba.excel.util.NumberUtils
;
/**
* Float and string converter
*
* @author zhuangjiaju
*/
public
class
FloatStringConverter
implements
Converter
<
Float
>
{
@Override
public
Class
supportJavaTypeKey
()
{
return
Float
.
class
;
}
@Override
public
CellDataTypeEnum
supportExcelTypeKey
()
{
return
CellDataTypeEnum
.
STRING
;
}
@Override
public
Float
convertToJavaData
(
CellData
cellData
,
ExcelContentProperty
contentProperty
)
{
return
Float
.
valueOf
(
cellData
.
getStringValue
());
}
@Override
public
CellData
convertToExcelData
(
Float
value
,
ExcelContentProperty
contentProperty
)
{
return
NumberUtils
.
formatToCellData
(
value
,
contentProperty
);
}
}
src/main/java/com/alibaba/excel/converters/integer/IntegerBooleanConverter.java
0 → 100644
浏览文件 @
9b3c8f12
package
com.alibaba.excel.converters.integer
;
import
com.alibaba.excel.converters.Converter
;
import
com.alibaba.excel.enums.CellDataTypeEnum
;
import
com.alibaba.excel.metadata.CellData
;
import
com.alibaba.excel.metadata.property.ExcelContentProperty
;
/**
* Integer and boolean converter
*
* @author zhuangjiaju
*/
public
class
IntegerBooleanConverter
implements
Converter
<
Integer
>
{
private
static
final
Integer
ONE
=
1
;
private
static
final
Integer
ZERO
=
0
;
@Override
public
Class
supportJavaTypeKey
()
{
return
Integer
.
class
;
}
@Override
public
CellDataTypeEnum
supportExcelTypeKey
()
{
return
CellDataTypeEnum
.
BOOLEAN
;
}
@Override
public
Integer
convertToJavaData
(
CellData
cellData
,
ExcelContentProperty
contentProperty
)
{
if
(
cellData
.
getBooleanValue
())
{
return
ONE
;
}
return
ZERO
;
}
@Override
public
CellData
convertToExcelData
(
Integer
value
,
ExcelContentProperty
contentProperty
)
{
if
(
ONE
.
equals
(
value
))
{
return
new
CellData
(
Boolean
.
TRUE
);
}
return
new
CellData
(
Boolean
.
FALSE
);
}
}
src/main/java/com/alibaba/excel/converters/integer/IntegerNumberConverter.java
0 → 100644
浏览文件 @
9b3c8f12
package
com.alibaba.excel.converters.integer
;
import
com.alibaba.excel.converters.Converter
;
import
com.alibaba.excel.enums.CellDataTypeEnum
;
import
com.alibaba.excel.metadata.CellData
;
import
com.alibaba.excel.metadata.property.ExcelContentProperty
;
/**
* Integer and number converter
*
* @author zhuangjiaju
*/
public
class
IntegerNumberConverter
implements
Converter
<
Integer
>
{
@Override
public
Class
supportJavaTypeKey
()
{
return
Integer
.
class
;
}
@Override
public
CellDataTypeEnum
supportExcelTypeKey
()
{
return
CellDataTypeEnum
.
NUMBER
;
}
@Override
public
Integer
convertToJavaData
(
CellData
cellData
,
ExcelContentProperty
contentProperty
)
{
return
cellData
.
getDoubleValue
().
intValue
();
}
@Override
public
CellData
convertToExcelData
(
Integer
value
,
ExcelContentProperty
contentProperty
)
{
return
new
CellData
(
value
.
doubleValue
());
}
}
src/main/java/com/alibaba/excel/converters/integer/IntegerStringConverter.java
0 → 100644
浏览文件 @
9b3c8f12
package
com.alibaba.excel.converters.integer
;
import
com.alibaba.excel.converters.Converter
;
import
com.alibaba.excel.enums.CellDataTypeEnum
;
import
com.alibaba.excel.metadata.CellData
;
import
com.alibaba.excel.metadata.property.ExcelContentProperty
;
import
com.alibaba.excel.util.NumberUtils
;
/**
* Integer and string converter
*
* @author zhuangjiaju
*/
public
class
IntegerStringConverter
implements
Converter
<
Integer
>
{
@Override
public
Class
supportJavaTypeKey
()
{
return
Integer
.
class
;
}
@Override
public
CellDataTypeEnum
supportExcelTypeKey
()
{
return
CellDataTypeEnum
.
STRING
;
}
@Override
public
Integer
convertToJavaData
(
CellData
cellData
,
ExcelContentProperty
contentProperty
)
{
return
Integer
.
valueOf
(
cellData
.
getStringValue
());
}
@Override
public
CellData
convertToExcelData
(
Integer
value
,
ExcelContentProperty
contentProperty
)
{
return
NumberUtils
.
formatToCellData
(
value
,
contentProperty
);
}
}
src/main/java/com/alibaba/excel/converters/longconverter/IntegerBooleanConverter.java
0 → 100644
浏览文件 @
9b3c8f12
package
com.alibaba.excel.converters.longconverter
;
import
com.alibaba.excel.converters.Converter
;
import
com.alibaba.excel.enums.CellDataTypeEnum
;
import
com.alibaba.excel.metadata.CellData
;
import
com.alibaba.excel.metadata.property.ExcelContentProperty
;
/**
* Integer and boolean converter
*
* @author zhuangjiaju
*/
public
class
IntegerBooleanConverter
implements
Converter
<
Integer
>
{
private
static
final
Integer
ONE
=
1
;
private
static
final
Integer
ZERO
=
0
;
@Override
public
Class
supportJavaTypeKey
()
{
return
Integer
.
class
;
}
@Override
public
CellDataTypeEnum
supportExcelTypeKey
()
{
return
CellDataTypeEnum
.
BOOLEAN
;
}
@Override
public
Integer
convertToJavaData
(
CellData
cellData
,
ExcelContentProperty
contentProperty
)
{
if
(
cellData
.
getBooleanValue
())
{
return
ONE
;
}
return
ZERO
;
}
@Override
public
CellData
convertToExcelData
(
Integer
value
,
ExcelContentProperty
contentProperty
)
{
if
(
ONE
.
equals
(
value
))
{
return
new
CellData
(
Boolean
.
TRUE
);
}
return
new
CellData
(
Boolean
.
FALSE
);
}
}
src/main/java/com/alibaba/excel/converters/longconverter/LongNumberConverter.java
0 → 100644
浏览文件 @
9b3c8f12
package
com.alibaba.excel.converters.longconverter
;
import
com.alibaba.excel.converters.Converter
;
import
com.alibaba.excel.enums.CellDataTypeEnum
;
import
com.alibaba.excel.metadata.CellData
;
import
com.alibaba.excel.metadata.property.ExcelContentProperty
;
/**
* Long and number converter
*
* @author zhuangjiaju
*/
public
class
LongNumberConverter
implements
Converter
<
Long
>
{
@Override
public
Class
supportJavaTypeKey
()
{
return
Long
.
class
;
}
@Override
public
CellDataTypeEnum
supportExcelTypeKey
()
{
return
CellDataTypeEnum
.
NUMBER
;
}
@Override
public
Long
convertToJavaData
(
CellData
cellData
,
ExcelContentProperty
contentProperty
)
{
return
cellData
.
getDoubleValue
().
longValue
();
}
@Override
public
CellData
convertToExcelData
(
Long
value
,
ExcelContentProperty
contentProperty
)
{
return
new
CellData
(
value
.
doubleValue
());
}
}
src/main/java/com/alibaba/excel/converters/longconverter/LongStringConverter.java
0 → 100644
浏览文件 @
9b3c8f12
package
com.alibaba.excel.converters.longconverter
;
import
com.alibaba.excel.converters.Converter
;
import
com.alibaba.excel.enums.CellDataTypeEnum
;
import
com.alibaba.excel.metadata.CellData
;
import
com.alibaba.excel.metadata.property.ExcelContentProperty
;
import
com.alibaba.excel.util.NumberUtils
;
/**
* Long and string converter
*
* @author zhuangjiaju
*/
public
class
LongStringConverter
implements
Converter
<
Long
>
{
@Override
public
Class
supportJavaTypeKey
()
{
return
Long
.
class
;
}
@Override
public
CellDataTypeEnum
supportExcelTypeKey
()
{
return
CellDataTypeEnum
.
STRING
;
}
@Override
public
Long
convertToJavaData
(
CellData
cellData
,
ExcelContentProperty
contentProperty
)
{
return
Long
.
valueOf
(
cellData
.
getStringValue
());
}
@Override
public
CellData
convertToExcelData
(
Long
value
,
ExcelContentProperty
contentProperty
)
{
return
NumberUtils
.
formatToCellData
(
value
,
contentProperty
);
}
}
src/main/java/com/alibaba/excel/util/NumberUtils.java
0 → 100644
浏览文件 @
9b3c8f12
package
com.alibaba.excel.util
;
import
java.math.RoundingMode
;
import
java.text.DecimalFormat
;
import
com.alibaba.excel.metadata.CellData
;
import
com.alibaba.excel.metadata.property.ExcelContentProperty
;
/**
* Number utils
*
* @author zhuangjiaju
*/
public
class
NumberUtils
{
private
NumberUtils
()
{}
/**
* format
*
* @param num
* @param contentProperty
* @return
*/
public
static
CellData
formatToCellData
(
Number
num
,
ExcelContentProperty
contentProperty
)
{
if
(
contentProperty
.
getNumberFormatProperty
()
==
null
||
StringUtils
.
isEmpty
(
contentProperty
.
getNumberFormatProperty
().
getFormat
()))
{
return
new
CellData
(
num
.
toString
());
}
String
format
=
contentProperty
.
getNumberFormatProperty
().
getFormat
();
RoundingMode
roundingMode
=
contentProperty
.
getNumberFormatProperty
().
getRoundingMode
();
DecimalFormat
decimalFormat
=
new
DecimalFormat
(
format
);
decimalFormat
.
setRoundingMode
(
roundingMode
);
return
new
CellData
(
decimalFormat
.
format
(
num
));
}
}
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录