当前位置:编程学习 > C#/ASP.NET >>

我的ListView导出Excel代码有问题,解决问题就给分!

//导出为Excel的方法
public void ExportExcel(ListView lv)
{
if(lv.Items == null) return;

string saveFileName="";
bool fileSaved=false;
SaveFileDialog saveDialog=new SaveFileDialog();
saveDialog.DefaultExt ="xls";
saveDialog.Filter="Excel文件|*.xls";
saveDialog.FileName ="Sheet1";
saveDialog.ShowDialog();
saveFileName=saveDialog.FileName;
if(saveFileName.IndexOf(":")<0) return; //被点了取消
   
Excel.Application xlApp=new Excel.Application();

if(xlApp==null)
{
MessageBox.Show("无法创建Excel对象,可能您的机子未安装Excel");
return;
}

Excel.Workbooks workbooks=xlApp.Workbooks;
Excel.Workbook workbook=workbooks.Add(Excel.XlWBATemplate.xlWBATWorksheet);
Excel.Worksheet worksheet=(Excel.Worksheet)workbook.Worksheets[1];//取得sheet1
Excel.Range range;

long totalCount=lv.Items.Count;
long rowRead=0;
float percent=0;

worksheet.Cells[1,1]="产品信息";
//写入字段
for(int i=0;i<lv.Columns.Count;i++)
{
worksheet.Cells[2,i+1]=lv.Columns[i];
range=(Excel.Range)worksheet.Cells[2,i+1];  //////运行的时候,这里会报异常,显示未设置值
range.Interior.ColorIndex = 15;
range.Font.Bold = true;
  
}
//写入数值
//this.CaptionVisible = true;
   
for(int r=0;r<lv.Items.Count;r++)
{
for(int i=0;i<lv.Columns.Count;i++)
{
worksheet.Cells[r+3,i+1]=lv.Items[r].SubItems[i];   
}
rowRead++;
percent=((float)(100*rowRead))/totalCount;    
// this.CaptionText = "正在导出数据["+ percent.ToString("0.00")  +"%]...";
Application.DoEvents();
}
//this.CaptionVisible = false;
//this.CaptionText = oldCaption;

range=worksheet.get_Range(worksheet.Cells[2,1],worksheet.Cells[lv.Items.Count+2,lv.Columns.Count]);
range.BorderAround(Excel.XlLineStyle.xlContinuous,Excel.XlBorderWeight.xlThin,Excel.XlColorIndex.xlColorIndexAutomatic,null);
   
range.Borders[Excel.XlBordersIndex.xlInsideHorizontal].ColorIndex = Excel.XlColorIndex.xlColorIndexAutomatic;
range.Borders[Excel.XlBordersIndex.xlInsideHorizontal].LineStyle =Excel.XlLineStyle.xlContinuous;
range.Borders[Excel.XlBordersIndex.xlInsideHorizontal].Weight =Excel.XlBorderWeight.xlThin;

if(lv.Columns.Count>1)
{
range.Borders[Excel.XlBordersIndex.xlInsideVertical].ColorIndex =Excel.XlColorIndex.xlColorIndexAutomatic;
range.Borders[Excel.XlBordersIndex.xlInsideVertical].LineStyle = Excel.XlLineStyle.xlContinuous;
range.Borders[Excel.XlBordersIndex.xlInsideVertical].Weight = Excel.XlBorderWeight.xlThin;
}

if(saveFileName!="")
{    
try
{
workbook.Saved =true;   
workbook.SaveCopyAs(saveFileName);
fileSaved=true;
}
catch(Exception ex)
{
fileSaved=false;
MessageBox.Show("导出文件时出错,文件可能正被打开!\n"+ex.Message);
}
}
else
{
fileSaved=false;
}   
xlApp.Quit();   
GC.Collect();//强行销毁
if(fileSaved && File.Exists(saveFileName)) System.Diagnostics.Process.Start(saveFileName);
   
}
--------------------编程问答-------------------- 你也写清楚是什么问题,贴一大堆代码,谁有兴趣去看呀?
补充:.NET技术 ,  C#
CopyRight © 2012 站长网 编程知识问答 www.zzzyk.com All Rights Reserved
部份技术文章来自网络,