2. Step 2 Generate an Excel template to fill with source data in C#
a. Create excel application object
Microsoft.Office.Interop.Excel.Application xlsApp = null;
data:image/s3,"s3://crabby-images/6cac0/6cac0dd46b2c91794627282c0d73fed6efa5ea05" alt=""
Workbook wb=null;
b. Open the template and SaveCopyAs a new temporary template file name
fileName= templatePath + @"\template.xls";
excelFileName = tempFileName + "_template.xls";
tempFileName= tempFileName + "_template_Temp.xls";
xlsApp = new ApplicationClass();
wb = xlsApp.Workbooks.Open(fileName, Type.Missing, Type.Missing,
Type.Missing, Type.Missing, Type.Missing, Type.Missing,
Type.Missing, Type.Missing, Type.Missing, Type.Missing,
Type.Missing, Type.Missing, Type.Missing, Type.Missing);
wb.Unprotect(TemplatePassword);
data:image/s3,"s3://crabby-images/6cac0/6cac0dd46b2c91794627282c0d73fed6efa5ea05" alt=""
wb.SaveCopyAs(tempFileName);
c. Close the template and open the new temporary file
wb.Close(false, Type.Missing, Type.Missing);
xlsApp.Quit();
wb = xlsApp.Workbooks.Open(tempFileName, Type.Missing, Type.Missing,
Type.Missing, Type.Missing, Type.Missing, Type.Missing,
Type.Missing, Type.Missing, Type.Missing, Type.Missing,
Type.Missing, Type.Missing, Type.Missing, Type.Missing);
data:image/s3,"s3://crabby-images/6cac0/6cac0dd46b2c91794627282c0d73fed6efa5ea05" alt=""
d. Get master data from database and fill in each cell and set, validation lock property properly based on requirement.
ws = (Worksheet)wb.Worksheets[DataSourceSheet];
LoadDataSource(ws, wb, beginDate, endDate);
data:image/s3,"s3://crabby-images/6cac0/6cac0dd46b2c91794627282c0d73fed6efa5ea05" alt=""
.
data:image/s3,"s3://crabby-images/6cac0/6cac0dd46b2c91794627282c0d73fed6efa5ea05" alt=""
data:image/s3,"s3://crabby-images/6cac0/6cac0dd46b2c91794627282c0d73fed6efa5ea05" alt=""
private void LoadDataSource(Worksheet ws, Workbook wb, DateTime beginDate, DateTime endDate)
data:image/s3,"s3://crabby-images/fadc8/fadc87475c0a604562c53d1ce0aa3cd58aa8e33a" alt=""
{
DataSet ds = SqlHelper.ExecuteDataset(connnectionString, CommandType.Text, "");
//Generate the Base Info
ws.get_Range("A1",System.Type.Missing).Value2 = 0; //Check flag
ws.get_Range("A4",System.Type.Missing).Value2 = beginDate.ToString("yyyy-MM-dd");
ws.get_Range("A5",System.Type.Missing).Value2 = endDate.ToString("yyyy-MM-dd");
ws.get_Range("A6",System.Type.Missing).Value2 = beginDate.ToString(PlanDateFormat);
ws.get_Range("A7",System.Type.Missing).Value2 = _templatetype;
data:image/s3,"s3://crabby-images/f808d/f808dab32a53c4f032c00727b665ec78271457b6" alt=""
LoadActionStatus(wb, ws, ds.Tables[0]);
LoadPromotionType(wb, ws, ds.Tables[0]);
data:image/s3,"s3://crabby-images/f808d/f808dab32a53c4f032c00727b665ec78271457b6" alt=""
LoadUserDataSource(wb, ws, beginDate.ToString(PlanDateFormat));
data:image/s3,"s3://crabby-images/f808d/f808dab32a53c4f032c00727b665ec78271457b6" alt=""
LoadCategoryDataSource(ws);
data:image/s3,"s3://crabby-images/f808d/f808dab32a53c4f032c00727b665ec78271457b6" alt=""
//ws.Visible = XlSheetVisibility.xlSheetVisible;
}
data:image/s3,"s3://crabby-images/6cac0/6cac0dd46b2c91794627282c0d73fed6efa5ea05" alt=""
data:image/s3,"s3://crabby-images/6cac0/6cac0dd46b2c91794627282c0d73fed6efa5ea05" alt=""
private void LoadMaterialDataSource(Worksheet ws)
data:image/s3,"s3://crabby-images/fadc8/fadc87475c0a604562c53d1ce0aa3cd58aa8e33a" alt=""
{
string sql = "select MaterialCode, EnglighShortName as MaterialName from Material";
string conn = ConfigurationSettings.AppSettings["ConnString"];
Range rng = ws.get_Range("Q1",System.Type.Missing);
QueryTable qt = ws.QueryTables.Add("OLEDB;Provider=SQLOLEDB.1;" + conn, rng, sql);
qt.Refresh(System.Type.Missing);
qt.Name = "Material";
}
data:image/s3,"s3://crabby-images/6cac0/6cac0dd46b2c91794627282c0d73fed6efa5ea05" alt=""
private void LoadCategoryDataSource(Worksheet ws)
data:image/s3,"s3://crabby-images/fadc8/fadc87475c0a604562c53d1ce0aa3cd58aa8e33a" alt=""
{
string sql = "SELECT CategoryID, CategoryNameEn FROM Category WHERE Status = 3";
string conn = ConfigurationSettings.AppSettings["ConnString"];
Range rng = ws.get_Range("W1",System.Type.Missing);
QueryTable qt = ws.QueryTables.Add("OLEDB;Provider=SQLOLEDB.1;" + conn, rng, sql);
qt.Refresh(System.Type.Missing);
qt.Name = "Category";
}
e. Protected worksheets and workbook based on requirement
ws = (Worksheet) wb.Worksheets[SummarySheet];
data:image/s3,"s3://crabby-images/6cac0/6cac0dd46b2c91794627282c0d73fed6efa5ea05" alt=""
ws.Protect(TemplatePassword,System.Type.Missing,System.Type.Missing,System.Type.Missing,System.Type.Missing,System.Type.Missing,System.Type.Missing,System.Type.Missing,System.Type.Missing,System.Type.Missing,System.Type.Missing,System.Type.Missing,System.Type.Missing,System.Type.Missing,System.Type.Missing, System.Type.Missing);
data:image/s3,"s3://crabby-images/6cac0/6cac0dd46b2c91794627282c0d73fed6efa5ea05" alt=""
wb.Protect(TemplatePassword,System.Type.Missing, System.Type.Missing);
data:image/s3,"s3://crabby-images/6cac0/6cac0dd46b2c91794627282c0d73fed6efa5ea05" alt=""
data:image/s3,"s3://crabby-images/6cac0/6cac0dd46b2c91794627282c0d73fed6efa5ea05" alt=""
f. Save the temporary file as the final template name
wb.SaveCopyAs(excelFileName);
g. Close the template and release the excel resource
if (wb!=null)
data:image/s3,"s3://crabby-images/6cac0/6cac0dd46b2c91794627282c0d73fed6efa5ea05" alt=""
data:image/s3,"s3://crabby-images/fadc8/fadc87475c0a604562c53d1ce0aa3cd58aa8e33a" alt=""
{
data:image/s3,"s3://crabby-images/f808d/f808dab32a53c4f032c00727b665ec78271457b6" alt=""
wb.Close(false, Type.Missing, Type.Missing);
data:image/s3,"s3://crabby-images/f808d/f808dab32a53c4f032c00727b665ec78271457b6" alt=""
}
data:image/s3,"s3://crabby-images/6cac0/6cac0dd46b2c91794627282c0d73fed6efa5ea05" alt=""
if(xlsApp != null)
data:image/s3,"s3://crabby-images/6cac0/6cac0dd46b2c91794627282c0d73fed6efa5ea05" alt=""
data:image/s3,"s3://crabby-images/fadc8/fadc87475c0a604562c53d1ce0aa3cd58aa8e33a" alt=""
{
data:image/s3,"s3://crabby-images/f808d/f808dab32a53c4f032c00727b665ec78271457b6" alt=""
xlsApp.Quit();
data:image/s3,"s3://crabby-images/f808d/f808dab32a53c4f032c00727b665ec78271457b6" alt=""
}
data:image/s3,"s3://crabby-images/6cac0/6cac0dd46b2c91794627282c0d73fed6efa5ea05" alt=""
//Remove the temporary file
data:image/s3,"s3://crabby-images/6cac0/6cac0dd46b2c91794627282c0d73fed6efa5ea05" alt=""
System.IO.File.Delete(tempFileName);
data:image/s3,"s3://crabby-images/6cac0/6cac0dd46b2c91794627282c0d73fed6efa5ea05" alt=""
. Step 3 Download the template from web site
4. Step 4 Fill in the template and verify the data
a. User fills in the data according to the description: list validation, free typing in, popup form etc.
b. Click the validation button in the sheet and validate the dat
5. Step 5 Upload the template to the web site