簡體   English   中英

如何使用互操作將Excel單元格值設置為string.empty?

[英]How can I set an excel cell value to string.empty using 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 ""!

我發現一個Excel成功將Cell [1,2]上的單元格值設置為“”。 您可以在下面查看附件。 這是怎么發生的? 有任何想法嗎? 我是否以錯誤的方式設置值?

MagicCell.xlsx

如果單元格值為文本,則Value2將返回字符串類型;如果單元格值為數字,則Value2將返回double類型。 如果單元格為空,則返回類型為COM對象為null。

因此,Value也將為null。 我認為(現在無法檢查)l,如果您檢查任何空白單元格的Text(即使您未將其設置為“”),它也會返回一個空字符串。

感謝@MátrayMárk,他的回答突然讓我震驚,因為單元格值類型可以解決問題。

所以我設置了:

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

和繁榮,string.empty有效!

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM