89ac0783
 
  jack
 
1.添加年级卷分析功能
 | 
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62 
 | 
  package com.fh.util;
  
  import java.util.Date;
  import java.util.List;
  import java.util.Map;
  
  import javax.servlet.http.HttpServletRequest;
  import javax.servlet.http.HttpServletResponse;
  
  import org.apache.poi.hssf.usermodel.HSSFCell;
  import org.apache.poi.hssf.usermodel.HSSFCellStyle;
  import org.apache.poi.hssf.usermodel.HSSFFont;
  import org.apache.poi.hssf.usermodel.HSSFSheet;
  import org.apache.poi.hssf.usermodel.HSSFWorkbook;
  import org.apache.poi.hssf.util.CellRangeAddress;
  import org.springframework.web.servlet.view.document.AbstractExcelView;
  
  import com.fh.util.PageData;
  import com.fh.util.Tools;
  public class ObjectExcelView2 extends AbstractExcelView{
  
  	@Override
  	protected void buildExcelDocument(Map<String, Object> model,
  			HSSFWorkbook workbook, HttpServletRequest request,
  			HttpServletResponse response) throws Exception {
  		// TODO Auto-generated method stub
  		Date date = new Date();
  		String filename = Tools.date2Str(date, "yyyyMMddHHmmss");
  		HSSFSheet sheet;
  		HSSFCell cell;
  		response.setContentType("application/octet-stream");
  		response.setHeader("Content-Disposition", "attachment;filename="+filename+".xls");
  		if(model.get("class")!=null && !model.get("class").toString().isEmpty()){
  			sheet = workbook.createSheet(model.get("class").toString());
  		}else{
  			sheet = workbook.createSheet("sheet1");
  		}
  		
  		
  		List<String> titles = (List<String>) model.get("titles");
  		int len = titles.size();
  		HSSFCellStyle headerStyle = workbook.createCellStyle(); //标题样式
  		headerStyle.setAlignment(HSSFCellStyle.ALIGN_CENTER);
  		headerStyle.setVerticalAlignment(HSSFCellStyle.VERTICAL_CENTER);
  		HSSFFont headerFont = workbook.createFont();	//标题字体
  		headerFont.setBoldweight(HSSFFont.BOLDWEIGHT_BOLD);
  		headerFont.setFontHeightInPoints((short)11);
  		headerStyle.setFont(headerFont);
  		short width = 20,height=25*20;
  		sheet.setDefaultColumnWidth(width);
  		for(int i=0; i<len; i++){ //设置标题
  			String title = titles.get(i);
  			cell = getCell(sheet, 0, i);
  			cell.setCellStyle(headerStyle);
  			setText(cell,title);
  		}
  		sheet.getRow(0).setHeight(height);
  		
  		HSSFCellStyle contentStyle = workbook.createCellStyle(); //内容样式
  		contentStyle.setAlignment(HSSFCellStyle.ALIGN_CENTER);
  		List<PageData> varList = (List<PageData>) model.get("varList");
  		int varCount = varList.size();
 
 | 
782f81b0
 
  jack
 
1.增加未知学生的判断
 | 
63 
 | 
  		Integer test_num =0;
 
 | 
89ac0783
 
  jack
 
1.添加年级卷分析功能
 | 
64
65 
 | 
  		for(int i=0; i<varCount; i++){
  			PageData vpd = varList.get(i);
 
 | 
782f81b0
 
  jack
 
1.增加未知学生的判断
 | 
66 
 | 
  			List<String> score = (List<String>)vpd.get("var6");
 
 | 
89ac0783
 
  jack
 
1.添加年级卷分析功能
 | 
67
68
69 
 | 
  			
  			for(int j=0;j<len;j++){
  				if(j<5){
 
 | 
782f81b0
 
  jack
 
1.增加未知学生的判断
 | 
70
71
72 
 | 
  					
  					if(score.size()>1){
  						CellRangeAddress region = new CellRangeAddress(test_num+1, test_num+score.size(), j, j);
 
 | 
89ac0783
 
  jack
 
1.添加年级卷分析功能
 | 
73
74
75
76 
 | 
  				        sheet.addMergedRegion(region);
  					}
  					
  					String varstr = vpd.getString("var"+(j+1)) != null ? vpd.getString("var"+(j+1)) : "";
 
 | 
782f81b0
 
  jack
 
1.增加未知学生的判断
 | 
77 
 | 
  					cell = getCell(sheet, test_num+1, j);
 
 | 
89ac0783
 
  jack
 
1.添加年级卷分析功能
 | 
78
79
80 
 | 
  					cell.setCellStyle(contentStyle);
  					setText(cell,varstr);
  				}else{
 
 | 
782f81b0
 
  jack
 
1.增加未知学生的判断
 | 
81 
 | 
  					//List<String> score = (List<String>)vpd.get("var6");
 
 | 
89ac0783
 
  jack
 
1.添加年级卷分析功能
 | 
82
83
84
85
86 
 | 
  					for(int x=0;x<score.size();x++){
  						String varstr = vpd.getString("var"+(j+1)) != null ? vpd.getString("var"+(j+1)) : "";
  						varstr = varstr.replace("[", "");
  						varstr = varstr.replace("]", "");
  						String[] s = varstr.split(",");
 
 | 
782f81b0
 
  jack
 
1.增加未知学生的判断
 | 
87 
 | 
  						cell = getCell(sheet, test_num+1+x, j);
 
 | 
89ac0783
 
  jack
 
1.添加年级卷分析功能
 | 
88
89
90
91
92
93 
 | 
  						cell.setCellStyle(contentStyle);
  						setText(cell,s[x]);
  					}
  		
  				}
  			}
 
 | 
782f81b0
 
  jack
 
1.增加未知学生的判断
 | 
94 
 | 
  			test_num = score.size()+test_num;
 
 | 
89ac0783
 
  jack
 
1.添加年级卷分析功能
 | 
95
96
97
98
99 
 | 
  		}
  		
  	}
  
  }
 
 |