david-PC\david
2018-06-12 f240ac3ccd37c541cab2c21cfc433d3510999a3c
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
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
package frame.file.office.excel;
 
import frame.file.FileIO;
import frame.file.FileIOContainer;
import frame.file.FileIOItem;
import frame.file.processor.Processor;
import frame.util.Util;
 
public class ExcelWriter {
    
    private Processor progressor;
 
    public ExcelWriter(Processor progressor) {
        this.progressor = progressor;
    }
    public DownloadResult writeOneFile(String ioCode, GetDataContext dataContext) {
        progressor.newTask("导出" + ioCode);
        try {
//            this.dataContext = dataContext;
 
            //1. get file io
            progressor.newPhase("getFileIO", "获取导出定义");
 
            FileIO fileIO = FileIOContainer.get(ioCode);
            if (fileIO == null) {
                progressor.appendMesage("can not find fileIO: " + ioCode);
                return null;
            }
 
            FileIOItem workingIoItem = fileIO.getItemList(FileIOItem.TypeCode_Output).get(0);
            
            if (workingIoItem == null) {
                progressor.appendMesage("can not find fileIO item: " + ioCode);
                return null;
            }
 
            progressor.endPhase();
 
            //2. get template file
            progressor.newPhase("getTemplate", "获取导出模板");
 
            String template = FileIOItem.extractFileName(workingIoItem.getToName());
 
            if (Util.isEmptyStr(template) || "*".equals(template)) {
                template = "standard.xlsx";
            }
 
            FileInfo templateFile = new FileInfo(Util.joinPath(Configer.path_template, template));
 
            if (!templateFile.Exists) {
                progressor.appendMesage("can not find template: " + templateFile.FullName);
                return null;
            }
 
            progressor.endPhase();
 
            //3. get temp file
            progressor.newPhase("createTempFile", "生成临时文件");
 
            String fileName = Path.GetFileNameWithoutExtension(template);
            String ext = Path.GetExtension(template);
            String tempFile = Util.joinPath(Configer.path_temp, fileName + Utils.newShortGUID() + ext);
 
            File.Copy(templateFile.FullName, tempFile);
 
            progressor.endPhase();
 
            //4. do write one file
            progressor.newPhase("exportData", "导出数据");
            processFile(tempFile);
            progressor.endPhase();
 
            return new DownloadResult(tempFile, fileName + ext);
        }
        finally {
            progressor.endTask();
        }
    }
 
    protected override void processSheets() {
        //1. get sheet
        progressor.newPhase("getSheet", "获取指定Sheet");
 
        String sheetname = FileIOItem.extractSheetName(workingIoItem.getToName());
        Sheet sheet = getSheetByName(sheetname);
 
        if (sheet == null) {
            progressor.appendMesage("can not find sheet: " + sheetname);
        }
 
        progressor.endPhase();
 
        //2. get data
        progressor.newPhase("GetData", "获取数据");
 
        NamedSql namedSQL = NamedSql.getInstance("getList");
        namedSQL.setParameter("tablename", workingIoItem.getFromName()).setParameter("filter", dataContext.getFilter()).setParameter("orderby", dataContext.getOrderBy());
        EntitySet entitySet = SQLRunner.getEntitySet(namedSQL.toSQLString());
 
        progressor.endPhase();
 
        //3. write data
        progressor.newPhase("writeData", "向Sheet内写入数据");
        writeOneSheet(sheet, entitySet);
        progressor.endPhase();
    }
}
 
}