excel 下载
public string CreateExcel(string SelectedBizType, string strReportDate, DropDownList ddlYQ, DropDownList ddlDataTable, ref string strFilePath)
{
Application m_objExcel = new Application();
int pid;
GetWindowThreadProcessId(new IntPtr(m_objExcel.Hwnd), out pid);
Workbooks m_objBooks = (Workbooks)m_objExcel.Workbooks;
string strTepPath = string.Empty;
string strTemplate = string.Empty;
if (SelectedBizType == "3a448698-b695-4a5a-b405-df18f44da86f")
{
strTepPath = ConfigurationManager.AppSettings["TRQBBTemplate"];
strTemplate = "天然气报表.xls";
}
else if (SelectedBizType == "969c388f-b0e2-4571-9876-4312b6a74a54")
{
strTepPath = ConfigurationManager.AppSettings["YCBBTemplate"];
strTemplate = "油藏报表.xls";
}
try
{
string strFileDir = strTepPath + strReportDate + @"/";//将导出的excel保存到该路径下
if (System.IO.Directory.Exists(strFileDir))//用来解决产能下载不稳定的问题
{
System.IO.Directory.Delete(strFileDir, true);//如果由于上一次导出未成功,而留下了痕迹,先删除此文件夹,再创建
}
System.IO.Directory.CreateDirectory(strFileDir);//创建导出文件夹
IDataBase oDB = DBFactory.GetDBInstance();
string strYQName = string.Empty;
string strTemplateChild = string.Empty;
//遍历油区
for (int i = 0; i < ddlYQ.Items.Count; i++)
{
strYQName = ddlYQ.Items[i].Text;
//遍历表
for (int j = 0; j < ddlDataTable.Items.Count; j++)
{
string strShortCode = string.Empty;
string strDtName = ddlDataTable.Items[j].Text;
strTemplateChild = "XXXXX.xls";
strShortCode = "XXXXXXXXXXXX";
//查询业务表数据
string strSql = string.Format("select * from " + strShortCode + " where ny='{0}' and yq='{1}'", strReportDate.Substring(0, 6), strYQName);
System.Data.DataTable dtLast = oDB.GetDataTable(strSql);
if (dtLast.Rows.Count == 0)
{
continue;
}
_Workbook m_objBook = (_Workbook)m_objBooks.Add(strTepPath + strTemplateChild);
Sheets m_objSheets = (Sheets)m_objBook.Worksheets;
_Worksheet m_objSheet = (_Worksheet)(m_objSheets.get_Item(1));
//查询表结构字段
// string strSchama = string.Format(@"select column_name EnKey from user_tab_columns
// where upper(table_name)=upper('{0}')
// order by COLUMN_ID", strShortCode);
// System.Data.DataTable dtCols = oDB.GetDataTable(strSchama);
// string colNames = string.Empty;
// for (int k = 0; k < dtCols.Rows.Count; k++)
// {
// colNames += dtCols.Rows[k][0].ToString() + ",";
// }
// if (colNames.Length > 0)
// {
// colNames = colNames.Substring(0, colNames.Length - 1);
// }
// DownloadMutiRefineTable ddR = new DownloadMutiRefineTable();
// System.Data.DataTable dtResource = ddR.GetTableSchema(dtLast, colNames);
System.Data.DataTable dtResource = dtLast.Copy();
//将dataTable中的数据写入sheet
int headRows = m_objSheet.UsedRange.Rows.Count;
for (int k = 0; k < dtResource.Rows.Count; k++)
{
for (int m = 0; m < dtResource.Columns.Count; m++)
{
if (dtResource.Columns[m].ColumnName.ToUpper() == "STATUS")
{
continue;
}
m_objSheet.Cells[k + headRows + 1, m + 1] = dtResource.Rows[k][m].ToString();
}
}
Range rCells = m_objSheet.Range[m_objSheet.Cells[headRows, 1],
m_objSheet.Cells[m_objSheet.UsedRange.Rows.Count, m_objSheet.UsedRange.Columns.Count]]; //shiying20140326 用来解决产能下载不稳定的问题
rCells.Borders.LineStyle = XlLineStyle.xlContinuous;
string save_path = strFileDir + ddlYQ.Items[i].Text + "_" + strReportDate + "_" + strTemplateChild;
m_objBook.SaveAs(save_path, XlFileFormat.xlXMLSpreadsheet, null, null, false, false,
XlSaveAsAccessMode.xlNoChange, null, null, null, null, null);
m_objBook.Close(false, null, null);
}
}
m_objBooks.Close();
m_objExcel.Application.Quit();
m_objExcel.Quit();
//将得到的excel打包
Crc32 crc = new Crc32();
strFilePath = strTepPath + strReportDate + strTemplate.Replace(".xls", ".zip");
ZipOutputStream zos = new ZipOutputStream(File.Create(strFilePath));
//zos.SetLevel(6);
DirectoryInfo di = new DirectoryInfo(strFileDir);
foreach (FileInfo item in di.GetFiles())
{
FileStream fs = File.OpenRead(item.FullName);
byte[] buffer = new byte[fs.Length];
fs.Read(buffer, 0, buffer.Length);
ZipEntry entry = new ZipEntry(strReportDate + strTemplate.Substring(0, strTemplate.Length - 4) + @"/" + item.Name);
entry.Size = fs.Length;
fs.Close();
crc.Reset();
crc.Update(buffer);
entry.Crc = crc.Value;
zos.PutNextEntry(entry);
zos.Write(buffer, 0, buffer.Length);
}
zos.Finish();
zos.Close();
System.IO.Directory.Delete(strFileDir, true);//删除导出文件夹
}
catch (Exception err)
{
Message = err.Message;
}
return Message;
}
excel 下载的更多相关文章
- Flex Excel下载
最近做Flex里的Excel下载,用as3xls进行Excel导出后,Excel修改编辑后老出现:不能以当前格式保存...若要保存所做的更改,请单击“确定”,然后将其另存为最新的格式. 最后通过JAV ...
- DevExpress中GridView Excel下载
DevExpress中GridView提供了许多Excel下载的方法,如gridView.ExportToExcelOld(sfdExcelDown.FileName); 在修改Bug时,遇到这样问题 ...
- ASP.NET Excel下载方法一览
方法一 通过GridView(简评:方法比较简单,但是只适合生成格式简单的Excel,且无法保留VBA代码),页面无刷新 aspx.cs部分 using System; using System.Co ...
- JS JQuery 操作: Json转 Excel 下载文件
方法的调用 var json = '[' + '{"申请流水号":"123456","保险公司":"测试数据",&quo ...
- 自己挖的坑自己填--jxl进行Excel下载堆内存溢出问题
今天在进行使用 jxl 进行 Excel 下载时,由于数据量大(4万多条接近5万条数据的下载),数据结构过于负责,存在大量大对象(虽然在对象每次用完都设置为null,但还是存在内存溢出问题),加上本地 ...
- PHP Excel 下载数据,并分页下载
直接上代码: 调用下载Excel: $total=$duoduo->count(MOD.' as a',$where); $objExcel= SelfExcelObject(); //导出 i ...
- SpringMVC生成Excel下载
SpringMVC controller里的方法: @RequestMapping(value="/notify/download",produces = {"appli ...
- C# MVC 自定义ActionResult实现EXCEL下载
前言 在WEB中,经常要使用到将数据转换成EXCEL,并进行下载.这里整理资料并封装了一个自定义ActionResult类,便于使用.如果文章对你有帮助,请点个赞. 话不多少,这里转换EXCEL使用的 ...
- 将页面内容转为Excel下载
使用:method1(table); 说明:参数table为table元素的ID; var idTmr; function getExplorer() { var explorer = window. ...
随机推荐
- Visual Studio的广告剧
一个热衷于code的developer,一个热衷于developer的girl,他们将发生怎样的故事? 第一集:<想做你的Code> 第二集:<让爱延长> 第三集:<幸福 ...
- 关于python27 中文编码
本博文已移致独立博客:www.pubwin2009.net 传送门:http://www.pubwin2009.net/index.php/pubwin/42.html 看了网上好多的资料,以前一直不 ...
- Hexo学习笔记--常用命令及部署步骤
参考资料: Hexo搭建Github静态博客:http://www.cnblogs.com/zhcncn/p/4097881.htmlHexo:独立博客新玩法:http://www.aips.me/h ...
- 安卓仿制新浪微博(一)之OAuth2授权接口
这里需要用到请求授权(authorize)以及获取授权(access_token) 第一步: 将新浪的sdk放在src/libs下面 二: //创建方法实现authorize public void ...
- Feedly订阅Blog部落格RSS网摘 - Blog透视镜
网络信息爆炸的时代,如何更有效率地阅读文章,订阅RSS网摘,可以快速地浏览文章标题,当对某些文章有兴趣时,才点下连结连到原网站,阅读更详细的文章,Feedly Reader阅读器除了提供在线版订阅RS ...
- Netbeans 注释模板配置
工具->模板->展开Java 选中Java类->在编辑器中打开 修改如下: <#if package?? && package != ""& ...
- TestNG基本注解(注释)
传统的方式来表示JUnit3中的测试方法是测试自己的名字前缀.标记一个类中的某些方法,具有特殊的意义,这是一个非常有效的方法,但命名不很好的扩展(如果我们想添加更多标签为不同的框架?),而非缺乏灵活性 ...
- 个性化定制——物流app
众所周知,在互联网不断迈进的大环境下,各行各业都不免在这大潮下纷纷卷入.人们早已不再满足于传统行业,即便是所谓的新兴行业所带来的体验,他们更多的希望能够在便捷的基础上获取更加个性化的服务,个性化服务在 ...
- hdu2082:简单母函数
题目大意: a,b,c,d...z这些字母的价值是1,2,3......26 给定 这26个字母分别的数量,求总价值不超过50的单词的数量 分析: 标准做法是构造母函数 把某个单词看作是,关于x的多项 ...
- FreeBSd ports 安装软件
1.ports的目录在/usr/ports2.POSTS安装软件有时可能这个包已经安装过了,会有提示,无法 继续安装.能够用提示中的参数:#make install clean FORCE_PKG_R ...