c# – 将空字段转换为零,然后转换为int?

c# – 将空字段转换为零,然后转换为int?,第1张

概述在我的程序中,我通过一个数据表循环来获取每个字段的数据.我的一行代码如下所示: int LYSMKWh = Convert.ToInt32(resultsDT.Rows[currentRow]["LYSMKWh"]); 基本上,我只是把单元格中的值转换成int32.我遇到一个问题,但是当该字段中的数据为空时.我收到无效转换错误消息,无法将“DBNull”转换为其他类型. 所以,我知道我可以检查字段 在我的程序中,我通过一个数据表循环来获取每个字段的数据.我的一行代码如下所示:
int LYSMKWh = Convert.ToInt32(resultsDT.Rows[currentRow]["LYSMKWh"]);

基本上,我只是把单元格中的值转换成int32.我遇到一个问题,但是当该字段中的数据为空时.我收到无效转换错误消息,无法将“dbnull”转换为其他类型.

所以,我知道我可以检查字段的值,然后再尝试通过这样做来转换它:

if (resultsDT.Rows[currentRow]["LYSMKWh"] == null)            {                resultsDT.Rows[currentRow]["LYSMKWh"] = 0;            }

但是,有没有更好的办法呢?有没有什么我可以做的“内联”,而我试图转换价值而不必诉诸使用if?

编辑:我尝试使用这个建议的方法:

int LYSMKWh = Convert.ToInt32(resultsDT.Rows[currentRow]["LYSMKWh"] ?? "0");

不幸的是,我仍然收到关于dbnull类型的无效转换错误消息.有人建议我可以有问题使用??如果任何一方的类型不同,运算符.

此外,由于我完全控制了我正在构建我的数据表的数据,所以我更改了它,以便不会将任何空值写入任何字段.所以,在这种情况下,这几乎不需要将null转换为int32.感谢所有的建议,大家!

解决方法 你可以这样做:
var LYSMKWh =    resultsDT.Rows[currentRow]["LYSMKWh"].Equals(dbnull.Value)    ? 0    : Convert.ToInt32(resultsDT.Rows[currentRow]["LYSMKWh"]);
总结

以上是内存溢出为你收集整理的c# – 将空字段转换为零,然后转换为int?全部内容,希望文章能够帮你解决c# – 将空字段转换为零,然后转换为int?所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/langs/1240176.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-06-06
下一篇 2022-06-06

发表评论

登录后才能评论

评论列表(0条)

保存