首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >精益求精文献

精益求精文献
EN

Stack Overflow用户
提问于 2012-01-19 15:30:35
回答 3查看 40.3K关注 0票数 10

我在这里发现了许多使用ExcelLibrary编辑超能力文件的建议,但我在任何地方都找不到任何文档。

http://code.google.com/p/excellibrary/

EN

回答 3

Stack Overflow用户

回答已采纳

发布于 2012-01-19 16:43:33

试试这个:

代码语言:javascript
运行
复制
var workbook = Workbook.Load("spreadsheet.xls");
var worksheet = workbook.Worksheets[0]; // assuming only 1 worksheet
var cells = worksheet.Cells;
var dataTable = new DataTable("datatable");

// add columns
dataTable.Columns.Add("column1");
dataTable.Columns.Add("column2");
...

// add rows
for (int rowIndex = cells.FirstRowIndex + 1; rowIndex <= cells.LastRowIndex; rowIndex++)
{
    var values = new List<string>();
    foreach(var cell in cells.GetRow(rowIndex))
    {
        values.Add(cell.Value.StringValue);
    }

    dataTable.LoadDataRow(values.ToArray(), true);
}

这并不是最漂亮的代码,但它返回一个DataTable。如果可能的话,我建议您直接使用这些值。而不是转换为DataTable,直接读取值并跳过此转换步骤。

票数 10
EN

Stack Overflow用户

发布于 2016-04-21 16:51:57

代码语言:javascript
运行
复制
//create new xls file
string file = "C:\newdoc.xls";
Workbook workbook = new Workbook(); 
Worksheet worksheet = new Worksheet("First Sheet"); 
worksheet.Cells[0, 1] = new Cell((short)1); 
worksheet.Cells[2, 0] = new Cell(9999999); 
worksheet.Cells[3, 3] = new Cell((decimal)3.45); 
worksheet.Cells[2, 2] = new Cell("Text string"); 
worksheet.Cells[2, 4] = new Cell("Second string"); 
worksheet.Cells[4, 0] = new Cell(32764.5, "#,##0.00"); 
worksheet.Cells[5, 1] = new Cell(DateTime.Now, @"YYYY-MM-DD"); worksheet.Cells.ColumnWidth[0, 1] = 3000; 
workbook.Worksheets.Add(worksheet); workbook.Save(file);

// open xls file
Workbook book = Workbook.Load(file);
Worksheet sheet = book.Worksheets[0];

// traverse cells
foreach (Pair, Cell> cell in sheet.Cells)
{ 
    dgvCells[cell.Left.Right, cell.Left.Left].Value = cell.Right.Value;
}

// traverse rows by Index
for (int rowIndex = sheet.Cells.FirstRowIndex; rowIndex <= sheet.Cells.LastRowIndex; rowIndex++)
{
    Row row = sheet.Cells.GetRow(rowIndex); 
    for (int colIndex = row.FirstColIndex; colIndex <= row.LastColIndex; colIndex++)
    {
        Cell cell = row.GetCell(colIndex);
    }
}
票数 1
EN

Stack Overflow用户

发布于 2012-01-19 15:32:44

我不知道这是什么,但我认为操纵Microsoft文档的首选方法是使用开放XMLSDK2.0

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/8928740

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档