1

我似乎无法获得 Excel 工作表中各个单元格的属性。我创建的函数创建了一个 Excel 工作表,用 DataSet 中的数据填充它,然后打印该工作表。

我遇到的问题是,当我打印工作表时,格式完全不正常 - 单元格太小并且很多信息被截断。我将如何设置单元格的宽度并更改字体?

这是我正在使用的一小部分内容,供您阅读:

// Add rows
iRow = 1;

foreach (DataRow row in table.Rows)
{
    iCol = 1;

    foreach (DataColumn col in table.Columns)
    {
        Parameters = new Object[2];
        Parameters[0] = iRow + 1;
        Parameters[1] = iCol;
        excelCell = excelSheet.GetType().InvokeMember("Cells",
          BindingFlags.GetProperty, null, excelSheet, Parameters);

        Parameters = new Object[1];
        Parameters[0] = row[col.ColumnName];
        excelCell.GetType().InvokeMember("Value",
          BindingFlags.SetProperty, null, excelCell, Parameters);

        iCol++;
    }
    iRow++;
}

似乎有很多例子说明如何通过早期绑定实现类似的东西,但我一定错过了后期绑定的一些东西。

4

3 回答 3

4

我不喜欢通过反思来解决这个问题。这是痛苦的。如果可以的话,我真的建议您查看新的“动态”关键字。你失去了 Intellisense(没什么大不了的,因为无论如何它在这种情况下并不是那么有用),但是代码更容易编写和理解。

下面是打开 Excel,创建工作簿,设置单元格值,设置字体大小,最后更改列宽的示例:

var excelType = Type.GetTypeFromProgID("Excel.Application");
dynamic excel = Activator.CreateInstance(excelType);
excel.Visible = true;
excel.Workbooks.Add();
excel.Cells(1, 1).Value = "Hello";
excel.Cells(1, 1).Font.Size = "14";
excel.Columns(@"A:A").ColumnWidth = 20;

如果您不确定如何做某事,您基本上可以在 Excel 中记录一个宏,然后查看代码。您几乎可以将其剪切并粘贴到您的 C# 代码中。

于 2012-07-06T00:26:41.663 回答
1

更改单元格的宽度与更改列的宽度相同

看看这有帮助吗?(未经测试

// Set the column width
public void SetColWdth(string rng, double wdth)
{
    Range = excelSheet.GetType().InvokeMember("Range",
    BindingFlags.GetProperty,null, excelSheet, new object [] {rng});
    object [] args = new object [] {wdth};
    Range. GetType().InvokeMember ("Columnwdth",
    BindingFlags.SetProperty, null, Range, args);
}

对于字体,看看是否有帮助?

从上面的链接中引用以防万一它死了

foreach (string line in header)
{

    Object entireRow = GetRow(sheet, columnCount, rowOffset);
    entireRow.GetType().InvokeMember("MergeCells",
    BindingFlags.SetProperty, null, entireRow,
    new object[] { true });
    entireRow.GetType().InvokeMember("HorizontalAlignment",
    BindingFlags.SetProperty, null, entireRow, new object[] { 3 });
    Object tlCell = GetCell(sheet, 1, rowOffset);
    tlCell.GetType().InvokeMember("Value2", BindingFlags.SetProperty,
    null, tlCell, new object[] { "'" + line });
    Object font = tlCell.GetType().InvokeMember("Font",
    BindingFlags.GetProperty, null, tlCell, null);

    rowOffset++;
}

for (int col = 0; col < data.Columns.Count; col++)
{
    Object test = GetCell(sheet, col + 1, rowOffset);
    //DataTable Headers
    {
        Object erow = test.GetType().InvokeMember("EntireRow",
        BindingFlags.GetProperty, null, test, null);
        Object font = erow.GetType().InvokeMember("Font",
        BindingFlags.GetProperty, null, erow, null);
        erow.GetType().InvokeMember("HorizontalAlignment",
        BindingFlags.SetProperty, null, erow, new object[] { 3 });
        font.GetType().InvokeMember("Bold", BindingFlags.SetProperty,
        null, font, new object[] { true });
        test.GetType().InvokeMember("Value2", BindingFlags.SetProperty,
        null, test, new object[] { data.Columns[col].ColumnName.ToString() });
    }
}
于 2012-07-05T22:34:44.320 回答
1

使用 Siddharth 向我展示的内容,我能够从工作表中获取一个单元格范围并更改该范围的 ColumnWidth 属性:

//Get the first worksheet.
Parameters = new Object[1];
Parameters[0] = 1;
excelSheet = excelSheets.GetType().InvokeMember("Item",
    BindingFlags.GetProperty, null, excelSheets, Parameters);

//Set the Column Width within a large Range of cells.
Parameters = new Object[2];
Parameters[0] = "A1";
Parameters[1] = "E55";
excelRange = excelSheet.GetType().InvokeMember("Range",
    BindingFlags.GetProperty, null, excelSheet, Parameters);

Parameters = new Object[1];
Parameters[0] = 26;
excelRange.GetType().InvokeMember("ColumnWidth",
BindingFlags.SetProperty, null, excelRange, Parameters);

我可以使用此方法通过将“ColumnWidth”替换为我想要设置的任何属性来更改该范围内的任何单元格属性。


要更改字体,我首先需要将单元格的 Font 属性作为对象,然后使用该对象访问字体属性:

object cellFont = excelCell.GetType().InvokeMember("Font",
    BindingFlags.GetProperty, null, excelCell, null);

Parameters = new Object[1];
Parameters[0] = true;
cellFont.GetType().InvokeMember("Bold",
BindingFlags.SetProperty, null, cellFont, Parameters);

谢谢!

于 2012-07-06T13:47:55.923 回答