如何使用interop将excel单元格值设置为string.empty?

时间:2017-12-22 02:40:19

标签: c# excel com-interop

我使用以下方法设置excel单元格值:

newSheet.Cells[23,2].Value2 = "";
newSheet.Cells[23,2].Value = "";

但奇怪的是,当我再次获得该值时,它总是返回null,为什么会这样?

var tt = newSheet.Cells[23,2].Value; //null
var tt2 = newSheet.Cells[23,2].Value2; //null
var tt3 = newSheet.Cells[23,2].Text; //this is ""!

我找到了一个成功将单元格值设置为""在Cell [1,2]上。您可以查看下面的附件。这是怎么发生的?有任何想法吗?我是以错误的方式设置值吗?

MagicCell.xlsx

2 个答案:

答案 0 :(得分:0)

如果单元格值是文本,则Value2将返回类型字符串,如果单元格值为number,则Value2将返回double类型。如果单元格为空,则返回类型为COM对象null。

所以Value也是null。我想(现在不能检查)l,如果检查任何空白单元格的文本(即使你没有将它设置为“”),它将返回一个空字符串。

答案 1 :(得分:0)

感谢@MátrayMárk,他的答案突然让我觉得单元格值类型可能会起作用。

所以我设置了:

newSheet.Cells[23,2].NumberFormat = "@";

繁荣,string.empty有效!