# excel-spring-boot-starter
**Repository Path**: kcrlyang/excel-spring-boot-starter
## Basic Information
- **Project Name**: excel-spring-boot-starter
- **Description**: EasyExcel spring boot 封装
- **Primary Language**: Unknown
- **License**: Apache-2.0
- **Default Branch**: master
- **Homepage**: None
- **GVP Project**: No
## Statistics
- **Stars**: 0
- **Forks**: 66
- **Created**: 2020-11-23
- **Last Updated**: 2020-12-18
## Categories & Tags
**Categories**: Uncategorized
**Tags**: None
## README
## EasyExcel
EasyExcel是一个基于Java的简单、省内存的读写Excel的开源项目。在尽可能节约内存的情况下支持读写百M的Excel。
64M内存1分钟内读取75M(46W行25列)的Excel,当然还有急速模式能更快,但是内存占用会在100M多一点
  
## spring boot stater依赖
- 方便在 web 环境下使用 `easyexcel` ,已上传至 maven 仓库
```xml
    com.pig4cloud.excel
    excel-spring-boot-starter
    0.0.6
```
## 使用方法
只需要在 `Controller` 层返回 List 并增加 `@ResponseExcel`注解即可
```java
@Documented
@Target(ElementType.METHOD)
@Retention(RetentionPolicy.RUNTIME)
public @interface ResponseExcel {
	String name() default "";
	ExcelTypeEnum suffix() default ExcelTypeEnum.XLSX;
	String password() default "";
	String[] sheet() default {};
	boolean inMemory() default false;
	String template() default "";
	String[] include() default {};
	String[] exclude() default {};
	Class extends WriteHandler>[] writeHandler() default {};
	Class extends Converter>[] converter() default {};
}
```
## 基础用法
- 返回单 `sheet`, 全部字段导出
```java
@ResponseExcel(name = "lengleng", sheet = "demoList")
@GetMapping("/e1")
public List e1() {
    List dataList = new ArrayList<>();
    for (int i = 0; i < 100; i++) {
        DemoData data = new DemoData();
        data.setUsername("tr1" + i);
        data.setPassword("tr2" + i);
        dataList.add(data);
    }
    return dataList;
}
// 实体对象
@Data
public class DemoData {
	private String username;
	private String password;
}
```

- 自定义字段属性
```java
@Data
public class DemoData {
    @ColumnWidth(50)  // 定义宽度
	@ExcelProperty("用户名") // 定义列名称
    @ContentStyle(fillPatternType = FillPatternType.SOLID_FOREGROUND, fillForegroundColor = 40)
	private String username;
	@ExcelProperty("密码")
	private String password;
}
```

-  忽略部分字段
```java
@Data
public class DemoData {
    @ColumnWidth(50)  // 定义宽度
	@ExcelProperty("用户名") // 定义列名称
    @ContentStyle(fillPatternType = FillPatternType.SOLID_FOREGROUND, fillForegroundColor = 40)
	private String username;
	@ExcelProperty("密码")
	private String password;
}
```

## 导出多sheet
```java
@ResponseExcel(name = "lengleng", sheet = {"第一个sheet","第二个sheet"})
@GetMapping("/e1")
public List> e1() {
    List> lists = new ArrayList<>();
    lists.add(list());
    lists.add(list());
    return lists;
}
```

## 设置导出加密码
```java
	@ResponseExcel(name = "lengleng", sheet = "sheetName",password = "lengleng")
	@GetMapping("/e1")
	public List> e1() {
		List> lists = new ArrayList<>();
		lists.add(list());
		lists.add(list());
		return lists;
	}
```

## 高级用法模板导出
```java
@ResponseExcel(name = "模板测试excel", sheet = "sheetName",template = "example.xlsx")
@GetMapping("/e1")
public List e1() {
    return list();
}
```
## 其他用法
- 理论上支持 [alibaba/easyexcel](https://github.com/alibaba/easyexcel) v2.2.6 版本的大部分配置
- 支持 [alibaba/easyexcel](https://www.yuque.com/easyexcel/doc/write) 原生的配置注解
- [github stater 地址,可fork 魔改](https://github.com/pigxcloud/excel-spring-boot-starter)