在每天黄金时刻将数据库中数据获取包装成Excel表
过程:
1.由Timer对象实现安排指定的任务在指定的时间进行重复的固定的延迟操作
a.设定时间间隔24小时:PERIOD_DAY = 24 * 60 * 60 * 100;
b.指定每天执行操作的时间:本文中设置时间使用Calendar对象,其中Calendar.HOUR_OF_DAY 与 Calendar.HOUR(一天12制)不同的是,其是24制的,对应一天24小时。
c.比较当前时间与设置时间的前后
d.执行操作:timer.schedule("任务对象","执行时间","时间间隔");
代码:
public class TimerManager {
//设置时间间隔24小时
private static final long PERIOD_DAY = 24 * 60 * 60 * 1000;
public TimerManager() {
Calendar calendar = Calendar.getInstance();
calendar.set(Calendar.HOUR_OF_DAY,14);
calendar.set(Calendar.MINUTE, 28);
calendar.set(Calendar.SECOND, 0);
Date date=calendar.getTime();
//判断当前时间与设置时间的前后,如果当前时间在设置时间之后,
//将设置时间日期往后推迟一天,以当前时间为准 。
if (date.before(new Date())) {
date = this.addDay(date, 1);
}
Timer timer = new Timer();
RunTimerTask task = new RunTimerTask(); //任务对象
//执行操作
timer.schedule(task,date,PERIOD_DAY);
}
// 增加或减少天数
public Date addDay(Date date, int num) {
Calendar calendar = Calendar.getInstance();
calendar.setTime(date);
calendar.add(Calendar.DAY_OF_MONTH, num);
return calendar.getTime();
}
}
2.将数据打包成Excel表
a.获取数据:
b.创建Excel表:创建Excel表具有的层次,如下:
工作薄 --> 数据表 --> 数据行 --> 单元格
WebBook --> Sheet --> Row --> Cell
c.向Excel表中输入数据:输入数据时,可分为表头与表身两部分,本文都是使用动态设置数据
输入表头时,从数据库中获取数据,可使用getMetaData()方法:tableHeader = resultSet.getMetaData();
输入表身时,需要利用类的反射机制,获取实体类的各种属性。
代码:
public class RunTimerTask extends TimerTask {
private static SimpleDateFormat formatter = new SimpleDateFormat(
"yyyy-MM-dd HH:mm:ss");
CustomerManagerImpl customerManagerImpl = new CustomerManagerImpl();
@Override
public void run() {
try {
// 第一步,创建一个webbook,对应一个Excel文件
HSSFWorkbook wb = new HSSFWorkbook();
// 第二步,在webbook中添加一个sheet,对应Excel文件中的sheet
HSSFSheet sheet = wb.createSheet("客户数据表");
// 第三步,在sheet中添加表头第0行,注意老版本poi对Excel的行数列数有限制short
HSSFRow row = sheet.createRow((int) 0);
// 第四步,创建单元格,并设置值表头 设置表头居中
HSSFCellStyle style = wb.createCellStyle();
style.setAlignment(HSSFCellStyle.ALIGN_CENTER); // 创建一个居中格式
String[] columnNames = getColumnNames();
for (int i = 0; i < columnNames.length; i++) {
HSSFCell cell = row.createCell(i);
cell.setCellValue(columnNames[i]);
cell.setCellStyle(style);
}
//从数据库中获取数据
List<Customer> customerList = getCustomerData();
Iterator<Customer> iterator = customerList.iterator(); //设置迭代器
int index = 0;
while (iterator.hasNext()) {
index++;
row = sheet.createRow(index);
Customer customer = (Customer) iterator.next();
// 利用反射,根据JavaBean属性的先后顺序,动态调用getXxx方法得到属性值
//因此为了与直接从数据库获取到的表头数据相对应,需要JavaBean中各属性get方法与数据库中各字段顺序一样。
Field[] fields = customer.getClass().getDeclaredFields();
for (int i = 0; i < fields.length; i++) {
HSSFCell hssfCell = row.createCell(i);
Field field = fields[i];
String fieldName = field.getName();
// 获取getXxx()方法相对应的方法名字符串
String methodName = "get"
+ fieldName.substring(0, 1).toUpperCase() + fieldName.substring(1);
// 获取类字段属性值
Object value = customer.getClass().getMethod(methodName, new Class[] {})
.invoke(customer, new Object[] {});
String textValue = null;
//可进行各种类型判断,并进行各种转换
if (value instanceof Boolean) {
boolean bText = (Boolean) value;
textValue = "男";
if (!bText) {
textValue = "女";
}
} else {
textValue = value.toString();
}
HSSFRichTextString hssfRichTextString = new HSSFRichTextString(
textValue);
hssfCell.setCellValue(hssfRichTextString);
}
}
return wb;
/*
* 将Excel文件保存到本地
* FileOutputStream fout = new
* FileOutputStream("F:/Users/shymain/customer.xls");
* wb.write(fout); fout.close();
*/
}
在每天黄金时刻将数据库中数据获取包装成Excel表的更多相关文章
- 将Oracle数据库中的数据写入Excel
将Oracle数据库中的数据写入Excel 1.准备工作 Oracle数据库"TBYZB_FIELD_PRESSURE"表中数据如图: Excel模板(201512.xls): 2 ...
- 在mysql数据库中制作千万级测试表
在mysql数据库中制作千万级测试表 前言: 最近准备深入的学一下mysql,包括各种引擎的特性.性能优化.分表分库等.为了方便测试性能.分表等工作,就需要先建立一张比较大的数据表.我这里准备先建一张 ...
- python制作简单excel统计报表3之将mysql数据库中的数据导入excel模板并生成统计图
python制作简单excel统计报表3之将mysql数据库中的数据导入excel模板并生成统计图 # coding=utf-8 from openpyxl import load_workbook ...
- sqlserver将数据库的数据导成excel文档方法
sqlserver将数据库的数据导成excel文档方法 最近公司需要下载uniport的数据跟之前的数据进行对比,所以避免不了需要将数据库的数据导出来,把SQLServer表中的数据导出为Excel文 ...
- 在MySQL数据库中创建一个完整的表
1.登陆成功后,首先进入某一个数据库 (不是指数据库服务器) use t1; //t1是数据库名 如图所示: 2.在此数据库中建立数据库表 2.1 先建立表结构(可以理解为表的列名,也就是字段名)在实 ...
- sql搜索数据库中具有某列的表
在接口中明明有某个节点,但在数据库中却找不到,为此本人写了一个sql,以供快速查找. Select distinct syscolumns.name,sysobjects.name from sysc ...
- NPOI从数据库中导出数据到Excel
首先要添加NPOI.dll程序集 https://yunpan.cn/cMeSTELJSXmJJ 访问密码 8d83 把里面的程序集都添加到引用里 下面的代码是从数据库导出到Excel { //pa ...
- 统计一个数据库中,无记录的表的sql语句
SQL Server数据库中统计无记录数的表 大家使用的时候,将sql脚本中的红色[TestDB] 换成你的目标数据库名称. /************************************ ...
- FM同步数据库中结构已经发生变化的表
接触Cognos很久了,最近遇到一个小问题. 在FM模型设计的过程中,有一张表jd_f_order.之后为了更全面的分析这个数据,在这个事实表中引入了一个新的字段商品类型字段,结构如图 但是由于jd_ ...
随机推荐
- Owin asp.net 脱离 IIS
http://www.cnblogs.com/jesse2013/p/owin-webserver.html
- Yet Another Number Sequence
题意: $F_0 = 0, F_1 = 1, F_n = F_{n-1} + F_{n-2}$ 求解$\sum_{i=1}^n{ F_i i^K } \ mod \ 10^9+7$. 解法: 记$ ...
- Flutter实战视频-移动电商-02.Flutter实战建立项目和编写入口文件
02.Flutter实战建立项目和编写入口文件 创建项目: flutter create flutter_shop 创建完成之后呢,它会提示我们, 进入flutter_shop的目录,然后执行flut ...
- CSS Unicode字体
在 CSS 中设置字体名称,直接写中文是可以的.但是在文件编码(GB2312.UTF-8 等)不匹配时会产生乱码的错误.xp 系统不支持 类似微软雅黑的中文. 方案一: 你可以使用英文来替代. 比如 ...
- MFC的CString使用
CString没有基类.一个CString对象由可变长度的一队字符组成.CString使用类似于Basic的语法提供函数和操作符.连接和比较操作符以及简化的内存管理使CString对象比普通字符串数组 ...
- [Xcode 实际操作]七、文件与数据-(15)单例模式的使用
目录:[Swift]Xcode实际操作 本文将演示单例对象的使用. 在项目名称上点击鼠标右键,弹出右键菜单,选择[New File]新建文件命令, 在弹出的模板选项窗口中,选择[Swift]文件选项, ...
- RobotFramework特性总结
robotframework是一款python编写的功能自动化测试框架.具备良好的可扩展性,支持关键字驱动,可以同时编写多种类型的客户端或者接口,可以进行分布式测试执行.主要用户轮次很多的验收测试和验 ...
- PAT 1040有几个PAT
原题:https://pintia.cn/problem-sets/994805260223102976/problems/994805282389999616 1040 有几个PAT (25 分) ...
- C 语言实例 - 判断元音/辅音
C 语言实例 - 判断元音/辅音 C 语言实例 C 语言实例 判断输入的字母是元音,还是辅音. 英语有26个字母,元音只包括 a.e.i.o.u 这五个字母,其余的都为辅音.y是半元音.半辅音字母,但 ...
- AngularJS - 入门小Demo
AngularJS四大特效 MVC模式.模块化设计.自动化双向数据绑定.依赖注入 如果了解了后端开发知识,想必对这些词汇不会陌生,AngularJS融合了后端开发的一些思想,虽然身为前端框架,但与jQ ...