导出 doc
...
/**
* 导出word
* @return
* @throws Exception
*/
@JCall
public String word() throws Exception{
String data=WebUtil.getParam("submitData");
// {"nf":"2005","jd":"第四季度:10月-12月","yf":"","zdy_ks":"","zdy_js":""} // 数据处理
List<Map<String, Object>> sj = sjcl(data); //文件名
String fileName = DateUtil.format("yyyyMMddHHmmssSSS", new Date())+ ".doc";
fileName = URLEncoder.encode(fileName, "utf-8"); CustomXWPFDocument doc = mortgage(sj,data); // (用于处理.docx文件的高(ish)级别类) 自定义 XWPFDocument,并重写 createPicture()方法 try{//输出文件 PropertiesUtil propertiesUtil=new PropertiesUtil("/db.properties");
// 作用是使客户端浏览器,区分不同种类的数据,并根据不同的MIME调用浏览器内不同的程序嵌入模块来处理相应的数据。
FileOutputStream os = new FileOutputStream(new File(System.getProperty("catalina.home")+"/webapps/"+this.getRequest().getContextPath()+"/doc/"+fileName));
// 获得字节流,通过该字节流的write(byte[] bytes)可以向response缓冲区中写入字节,再由Tomcat服务器将字节内容组成Http响应返回给浏览器。
// OutputStream os = getResponse().getOutputStream();
doc.write(os);
//os.flush();
os.close();
return fileName;
} catch (Exception e) {
e.printStackTrace();
// 没有数据 返回什么到前台呢
return "false";
}
} // 数据处理
private List<Map<String, Object>> sjcl(String data) throws Exception {
JSONObject Jdata =JSONObject.fromObject(data);
String nf = Jdata.get("nf").toString();
String jd = Jdata.get("jd").toString();
String yf = Jdata.get("yf").toString();
String zdy_ks = Jdata.get("zdy_ks").toString();
String zdy_js = Jdata.get("zdy_js").toString();
// {"nf":"2005","jd":"第四季度:10月-12月","yf":"","zdy_ks":"","zdy_js":""} String sql = " SELECT T.TASK_ID,T.TASK_NAME,T.XTYH_ID,T.TASK_DATE,T.TASK_TEXT, T.BY2,t.by3,T.CREATE_USER,T.CREATE_DATE,T.INSERT_PERSON,T.INSERT_TIME,T.DATA_FLAG,T.XMLX,T.SFGK,T.TASK_NAME_ID "
+" FROM FSXC3.T_FSXC_TASK T "
+" WHERE T.DATA_FLAG <> 'D' "
+" AND T.XTYH_ID='"+SysUtil.getUserId()+"' ";
// dateTime=dateTime+" 00:00:00";
// String sql = " select * from t_fsxc_task t where t.XTYH_ID='"+SysUtil.getUserId()+"' and t.TASK_DATE like to_date('"+dateTime+"','yyyy-MM-dd') and t.MODIFY_FLAG<>'D' ";
// date>='2010-01-01' and date<='2010-10-1'
if(!nf.equals("") && jd .equals("") && yf.equals("")){ // 年份不等于空,季度等于空,月份等于空 >>年度
// nf+="-01-01";
sql += " AND T.TASK_DATE like '%"+nf+"%' "; // 模糊查询 }else if(!jd.equals("")){ // 季度(问?第一:只选了季度;第二:季度加年份)
String jdks = "";
String jdjs = "";
if(jd.equals("第一季度:1月-3月")){
jdks += "-01-01";
jdjs += "-03-31";
}else if(jd.equals("第二季度:4月-6月")){
jdks += "-04-01";
jdjs += "-06-30";
}else if(jd.equals("第三季度:7月-9月")){
jdks += "-07-01";
jdjs += "-09-30";
}else if(jd.equals("第四季度:10月-12月")){
jdks += "-10-01";
jdjs += "-12-31";
}
if(!nf.equals("")){
sql += " AND T.TASK_DATE >= '"+nf+jdks+"' AND T.TASK_DATE <= '"+nf+jdjs+"' ";
}else{
// 获得当前年份 加上季度时间
Calendar date = Calendar.getInstance();
String year = String.valueOf(date.get(Calendar.YEAR)); sql +=" AND T.TASK_DATE >= '"+year+jdks+"' AND T.TASK_DATE <= '"+year+jdjs+"' ";
}
}else if(!yf.equals("")){ // 月份
// 获得当前年份 加上季度时间
Calendar date = Calendar.getInstance();
int year = date.get(Calendar.YEAR); // 年份 String Iyf = yf.substring(0,1); // 截取String中数字部分的月份
int month = Integer.parseInt(Iyf); // 如果有0就只有数字 String yfx ="-"+yf+"-01"; /////////////////////////////////////////////
// 获得某年某月的最后一天
Calendar cal = Calendar.getInstance();
//设置年份
cal.set(Calendar.YEAR,year);
//设置月份
cal.set(Calendar.MONTH, month-1);
//获取某月最大天数
int lastDay = cal.getActualMaximum(Calendar.DAY_OF_MONTH);
/////////////////////////////////////// String yfd ="-0"+Iyf+lastDay; // 没有31号的月份会不会报错 // 获取这个月的最后一天 if(!nf.equals("")){
sql += " AND T.TASK_DATE >= '"+nf+yfx+"' AND T.TASK_DATE <= '"+nf+yfd+"' ";
}else{
sql +=" AND T.TASK_DATE >= '"+year+yfx+"' AND T.TASK_DATE <= '"+year+yfd+"' ";
}
} if(!zdy_ks.equals("")){
sql +=" AND T.TASK_DATE >= '"+zdy_ks+"' ";
} if(!zdy_js.equals("")){
sql +=" AND T.TASK_DATE <= '"+zdy_js+"' ";
} // (List集合中的对象是一个Map对象,而这个Map对象的键是String类型,值是Object类型)
List<Map<String, Object>> sj = this.dBSelect(sql.toString()); // 调用查询数据库
return sj;
} // word
private CustomXWPFDocument mortgage(List<Map<String, Object>> sj,String tj) throws Exception {
JSONObject jsonObject=JSONObject.fromObject(tj);
//{"nf":"2005","jd":"第四季度:10月-12月","yf":"","zdy_ks":"","zdy_js":""}
String bt="";
if(!jsonObject.getString("nf").equals("")){
bt=jsonObject.getString("nf");
}else if(!jsonObject.getString("jd").equals("")){
bt+=jsonObject.getString("jd")+"个人工作";
}else if(!jsonObject.getString("yf").equals("")){
bt+=jsonObject.getString("yf")+"个人工作";
}
if(!jsonObject.getString("zdy_ks").equals("") && !jsonObject.getString("zdy_js").equals("")){
bt=jsonObject.getString("zdy_ks").replace("T00:00:00", "")+"到"+jsonObject.getString("zdy_js").replace("T00:00:00", "")+"个人工作";
} CustomXWPFDocument document= new CustomXWPFDocument(); //添加标题
XWPFParagraph titleParagraph = document.createParagraph(); //设置段落居中
titleParagraph.setAlignment(ParagraphAlignment.CENTER); XWPFRun titleParagraphRun = titleParagraph.createRun();
titleParagraphRun.setBold(true);
titleParagraphRun.setText(bt);
titleParagraphRun.setFontFamily("方正小标宋简体");
titleParagraphRun.setColor("000000");
titleParagraphRun.setFontSize(22); //换行
XWPFParagraph paragraph1 = document.createParagraph();
XWPFRun paragraphRun1 = paragraph1.createRun();
paragraphRun1.setText("\r"); for(int i=0;i<sj.size();i++){
//段落
XWPFParagraph firstParagraph = document.createParagraph();
XWPFRun run = firstParagraph.createRun();
String ybgcm=(i+1)+"."+SysUtil.toStr(sj.get(i).get("task_date"))+SysUtil.toStr(sj.get(i).get("task_name"))+"-"+SysUtil.toStr(sj.get(i).get("by2"))+" ("+SysUtil.toStr(sj.get(i).get("by3"))+")";
run.setText(ybgcm);
run.setBold(true);
run.setColor("000000");
run.setFontSize(15); //段落
XWPFParagraph Paragraph2 = document.createParagraph();
XWPFRun run2 = Paragraph2.createRun();
run2.setBold(false);
run2.setText("工作内容:"+SysUtil.toStr(sj.get(i).get("task_text")));
run2.setColor("000000");
run2.setFontSize(15); //段落
XWPFParagraph Paragraph3 = document.createParagraph();
XWPFRun run3 = Paragraph3.createRun();
run3.setBold(false);
run3.setText("附件:");
run3.setColor("000000");
run3.setFontSize(15); //获取附件
String sqlString ="select t.file_info_id,t.file_extend,t.file_info_c3,t.file_filename from T_P_FILE_INFO t where t.data_flag <> 'D' and t.file_index ='"+SysUtil.toStr(sj.get(i).get("task_id"))+"'";
List<Map<String, Object>> fjList=dBSelect(sqlString);
for(int j=0;j<fjList.size();j++){
String imagePath =SysUtil.toStr(fjList.get(j).get("file_info_id"))+"."+SysUtil.toStr(fjList.get(j).get("file_extend"));
String imgurl = System.getProperty("catalina.home")+"/webapps/webdav/"+imagePath;
int format;
if(imgurl.endsWith(".emf")) format = XWPFDocument.PICTURE_TYPE_EMF;
else if(imgurl.endsWith(".wmf")) format = XWPFDocument.PICTURE_TYPE_WMF;
else if(imgurl.endsWith(".pict")) format = XWPFDocument.PICTURE_TYPE_PICT;
else if(imgurl.endsWith(".jpeg") || imgurl.endsWith(".jpg")) format = XWPFDocument.PICTURE_TYPE_JPEG;
else if(imgurl.endsWith(".png")) format = XWPFDocument.PICTURE_TYPE_PNG;
else if(imgurl.endsWith(".dib")) format = XWPFDocument.PICTURE_TYPE_DIB;
else if(imgurl.endsWith(".gif")) format = XWPFDocument.PICTURE_TYPE_GIF;
else if(imgurl.endsWith(".tiff")) format = XWPFDocument.PICTURE_TYPE_TIFF;
else if(imgurl.endsWith(".eps")) format = XWPFDocument.PICTURE_TYPE_EPS;
else if(imgurl.endsWith(".bmp")) format = XWPFDocument.PICTURE_TYPE_BMP;
else if(imgurl.endsWith(".wpg")) format = XWPFDocument.PICTURE_TYPE_WPG;
else {
System.err.println("Unsupported picture: " + imgurl +
". Expected emf|wmf|pict|jpeg|png|dib|gif|tiff|eps|bmp|wpg"); //不是图片,直接输入超链接
appendExternalHyperlink(this.getRequest().getScheme()+"://"+this.getRequest().getServerName()+":"+this.getRequest().getServerPort()+"/webdav/"+imagePath,
fjList.get(j).get("file_filename").toString(), document.createParagraph());
continue;
} File dir = new File(imgurl);
if (dir.exists()) {
String picId = document.addPictureData(new FileInputStream(imgurl), format);
document.createPicture(picId, document.getNextPicNameNumber(format), 500, 400);
}
} } return document;
}
导出 doc的更多相关文章
- eclipse导出doc文档
选中需要导出的项目, 1 点击eclipse上面的Project,选择Generate javadoc..., 2 然后配置 javadoc command,比如我本地的路径为: C:\Program ...
- Eclipse文档注释导出doc
选择要导出的项目,右键选择Export 直接next,在最后finish之前加上编码格式.要不然会出现乱码
- eclipse导出doc帮助文档字符编码设置
- php导出word格式数据的代码
<?php /** * 生成word文档的类 * by www.jbxue.com */ class word { function start() { ...
- 使用PHP导出Word文档的原理和实例
PHP操作Word文档的方法有很多,这里再为大家提供一种方法. 原理 一般,有2种方法可以导出doc文档,一种是使用com,并且作为php的一个扩展库安装到服务器上,然后创建一个com,调用它的方 ...
- DevExpress ASPxHtmlEditor控件格式化并导出Word (修复中文字体导出丢失)
在前台页面中先插入一个ASPxHtmlEditor控件,名为ASPxHtmlEditor1. 我用的Dev版本为14.1 格式化文本 在后台插入如下代码 1 const string css ...
- php导出word格式数据的代码(转)
本节内容:一个php导出文档的类 例子:<?php /*** 生成word文档的类* by www.jbxue.com*/class word{ function start() ...
- PHP网页导出Word文档的方法分离
今天要探讨的是PHP网页导出Word文档的方法,使用其他语言的朋友也可以参考,因为原理是差不多的. 原理 一般,有2种方法可以导出doc文档,一种是使用com,并且作为php的一个扩展库安装到服务器上 ...
- PHP导出excel word的代码
php导出为word原理 一般,有2种方法可以导出doc文档,一种是使用com,并且作为php的一个扩展库安装到服务器上,然后创建一个com,调用它的方法.安装过office的服务器可以调用一个叫wo ...
随机推荐
- Kettle学习笔记(四)— 总结
目录 Kettle学习笔记(一)- 环境部署及运行 Kettle学习笔记(二)- 基本操作 kettle学习笔记(三)- 定时任务的脚本执行 Kettle学习笔记(四)- 总结 Kettle中设置编码 ...
- 日常学习用到的Git指令
Git 常用Git指令 (本地) git init - 将文件夹初始化为Git仓库 git add - 将工作区的指定文件放入暂存区 git status - 查看工作区和暂存区的状态 git com ...
- caffe转换变量时的gflags问题
先解决错误7,解决方式来自于http://blog.csdn.net/wishchin/article/details/51888566这篇博文,感谢博主 只需要添加上 #pragma comment ...
- linux主机互信操作
一.主机互信原理两个主机之间ssh登录需要提示输入对方的密码,当频繁需要登录操作时,可以通过linux公钥和秘钥,建立双机信任关系.把你源主机的公钥文件内容追加到目的主机对应用户下的authorize ...
- 洛谷4400 BlueMary的旅行(分层图+最大流)
qwq 首先,我们观察到题目中提到的每天只能乘坐一次航班的限制,很容易想到建分层图,也就是通过枚举天数,然后每天加入一层新的点. (然而我一开始想的却是erf) 考虑从小到大枚举天数,然后每次新建一层 ...
- 洛谷3613睡觉困难综合征(LCT维护链信息(前后缀)+贪心)
这个题目还是很好啊QWQ很有纪念意义 首先,如果在序列上且是单次询问的话,就是一个非常裸的贪心了QWQ这也是NOI当时原题的问题和数据范围 我们考虑上树的话,应该怎么做? 我的想法是,对于每一位建一个 ...
- IEEE 754 浮点数加减运算
电子科技大学 - 计算机组成原理 小数的十进制和二进制转换 移码 定义:[X]移 = X + 2n ( -2n ≤ X < 2n ) X为真值,n为整数的位数 数值位和X的补码相同,符号位与补码 ...
- JavaScript兼容性汇总
一般兼容性问都体现到DOM和事件上 只聊ie6+版本浏览器,希望小伙伴们别纠结更低版本浏览器哈^_^ DOM 获取元素 document.getElementsByclassName 不兼容ie6 ...
- 如何快速体验鸿蒙全新声明式UI框架ArkUI?
HDC2021将于10月22日在东莞松山湖正式开幕,大会将设立Codelab体验专区,超多好玩.有趣的Demo等你体验.想快速入门HarmonyOS?学习HarmonyOS新特性?以下几个Codela ...
- WPF 排版基础
一.WPF 排版基础 WPF使用控制面板来进行排版,控制面板实际上是一种可以放入WPF界面元素的容器.当用户把界面元素放入控制面板后,WPF会自动把这些界面元素放在它认为合适的地方.WPF开发人员需要 ...