c#对Excel操作

本代码可以对Excel生成自定义的交叉表头,可以制作自定义的交叉报表。

代码使用的是Owc11库,要先安装这个库,再将其引用到项目中。

 对excel主要的操作有:

1.新建excel进程

2.获得操作范围

3.对单元格进行纵向横向合并

4.设置样式

5.导出

6.以网面形式显示

private   void  button1_Click( object  sender, EventArgs e)
        
{
            
            Microsoft.Office.Interop.Owc11.SpreadsheetClass xlsheet 
= new Microsoft.Office.Interop.Owc11.SpreadsheetClass();
            
            FillInLeft(
1, xlsheet, sList, xLevel);

            
try
            
{                               
               
//导出
                xlsheet.Export("../../TestOWC.htm", Microsoft.Office.Interop.Owc11.SheetExportActionEnum.ssExportActionNone, Microsoft.Office.Interop.Owc11.SheetExportFormat.ssExportHTML);
            }

            
catch
            
{
                MessageBox.Show(
"Export Error!");
            }


            
string strFileName = @"D:TestOWC.htm";
            Object refmissing 
= System.Reflection.Missing.Value;
            axWebBrowser1.Navigate(strFileName, 
ref refmissing, ref refmissing, ref refmissing, ref refmissing);
            
        }


private   void  FillInLeft( int  beginRow, Microsoft.Office.Interop.Owc11.SpreadsheetClass xlsheet, Stack sList,  int  xlevel)
        
{//xml中的节点写入Excel的顺序是:由上往上,由左往右
            
//beginRow:从第几行开始写入 xlsheet:目的Excel文件 sList:存入节点的堆栈 xlevle:深度
            int row = beginRow; //int row = ((node)sList.Peek()).i;
            while (sList.Count > 0)
            
{
                node node1 
= (node)sList.Pop();
                
if (node1.i > 1)
                
{//有子节点且子节点在2个以上,需纵向合并
                    xlsheet.get_Range(xlsheet.Cells[row, node1.j], xlsheet.Cells[row + node1.i - 1, node1.j]).set_MergeCells(true);
                }

                
if (node1.i == 0)
                
{
                    
if (node1.j < xlevel)
                    
{//叶节点不在最下层,则横向合并
                        xlsheet.get_Range(xlsheet.Cells[row, node1.j], xlsheet.Cells[row, xlevel]).set_MergeCells(true);
                    }

                }

                xlsheet.Cells[row, node1.j] 
= node1.n.Attributes.GetNamedItem("name").Value;
                
if (node1.i == 0//是叶节点,则下一个节点填在下一行
                    row += 1;
            }


            Microsoft.Office.Interop.Owc11.Range range 
= xlsheet.get_Range(xlsheet.Cells[11], xlsheet.Cells[xlsheet.ActiveSheet.UsedRange.Rows.Count, xlsheet.ActiveSheet.UsedRange.Columns.Count]);
            
//单元格文本水平居中对齐
            range.set_HorizontalAlignment(Microsoft.Office.Interop.Owc11.XlHAlign.xlHAlignCenter);
            
//单元格文本垂直居中对齐
            range.set_VerticalAlignment(Microsoft.Office.Interop.Owc11.XlVAlign.xlVAlignCenter);
            
//设置表头列宽
            range.set_ColumnWidth(14);
            
//设置边框
            range.Borders.set_LineStyle(Microsoft.Office.Interop.Owc11.XlLineStyle.xlContinuous);
        }
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
C# NPOI是一个用于在C#操作Excel的库。NPOI的行和列的索引都是从0开始的。NPOI支持读取Excel文件的两种格式:HSSF(.xls)和XSSF(.xlsx)。使用NPOI进行Excel操作的步骤如下: 1. 首先,将NPOI.dll导入你的项目中。在解决方案资源管理器中,右键点击项目,选择“引用”或“添加引用”,然后选择NPOI.dll进行导入。 2. 接着,引入NPOI的命名空间。在你的代码文件的开头,使用`using NPOI`来引入NPOI的命名空间。 3. 创建一个Workbook对象,表示一个工作簿。可以使用`HSSFWorkbook`或`XSSFWorkbook`类来创建对应格式的工作簿。 4. 获取工作簿中的工作表(Sheet)。可以使用`GetSheetAt`方法来获取指定索引的工作表,也可以使用`GetSheet`方法根据工作表名称来获取。 5. 在工作表中,可以使用`GetRow`方法获取指定索引的行,使用`GetCell`方法获取指定索引的单元格。 6. 对于读取操作,可以使用单元格的`ToString`方法获取单元格的值。对于写入操作,可以使用单元格的`SetCellValue`方法设置单元格的值。 7. 在完成操作后,记得保存工作簿,可以使用`Write`方法将工作簿保存到文件中,也可以使用`WriteTo`方法将工作簿保存到流中。 下面是一个示例代码,演示了如何使用NPOI读取和写入Excel文件: ```csharp using NPOI.HSSF.UserModel; using NPOI.SS.UserModel; using NPOI.XSSF.UserModel; // 读取Excel文件 IWorkbook workbook; using (FileStream file = new FileStream("path/to/excel.xlsx", FileMode.Open, FileAccess.Read)) { if (Path.GetExtension(file.Name).Equals(".xls")) workbook = new HSSFWorkbook(file); else workbook = new XSSFWorkbook(file); ISheet sheet = workbook.GetSheetAt(0); for (int rowIndex = 0; rowIndex <= sheet.LastRowNum; rowIndex++) { IRow row = sheet.GetRow(rowIndex); for (int cellIndex = 0; cellIndex < row.LastCellNum; cellIndex++) { ICell cell = row.GetCell(cellIndex); string cellValue = cell.ToString(); Console.WriteLine("Cell({0}, {1}): {2}", rowIndex, cellIndex, cellValue); } } } // 写入Excel文件 using (FileStream file = new FileStream("path/to/new_excel.xlsx", FileMode.Create, FileAccess.Write)) { IWorkbook workbook = new XSSFWorkbook(); ISheet sheet = workbook.CreateSheet("Sheet1"); for (int rowIndex = 0; rowIndex < 10; rowIndex++) { IRow row = sheet.CreateRow(rowIndex); for (int cellIndex = 0; cellIndex < 10; cellIndex++) { ICell cell = row.CreateCell(cellIndex); cell.SetCellValue("Data " + rowIndex + "-" + cellIndex); } } workbook.Write(file); } ```

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值