Convert string to nullable type (int, double, etc...)(将字符串转换为可空类型(int、double 等...))
问题描述
我正在尝试进行一些数据转换.不幸的是,大部分数据都在字符串中,应该是 int 或 double 等......
I am attempting to do some data conversion. Unfortunately, much of the data is in strings, where it should be int's or double, etc...
所以我得到的是这样的:
So what I've got is something like:
double? amount = Convert.ToDouble(strAmount);
这种方法的问题是如果 strAmount 为空,如果它是空的,我希望它为空,所以当我将它添加到数据库中时,该列将为空.所以我最终写了这个:
The problem with this approach is if strAmount is empty, if it's empty I want it to amount to be null, so when I add it into the database the column will be null. So I ended up writing this:
double? amount = null;
if(strAmount.Trim().Length>0)
{
amount = Convert.ToDouble(strAmount);
}
现在这工作正常,但我现在有五行代码而不是一行.这使事情变得更难阅读,尤其是当我有大量列要转换时.
Now this works fine, but I now have five lines of code instead of one. This makes things a little more difficult to read, especially when I have a large amount of columns to convert.
我想我会使用对字符串类和泛型的扩展来传递类型,这是因为它可以是双精度、整数或长整数.所以我尝试了这个:
I thought I'd use an extension to the string class and generic's to pass in the type, this is because it could be a double, or an int, or a long. So I tried this:
public static class GenericExtension
{
public static Nullable<T> ConvertToNullable<T>(this string s, T type) where T: struct
{
if (s.Trim().Length > 0)
{
return (Nullable<T>)s;
}
return null;
}
}
但我收到错误:无法将类型字符串"转换为T?"
But I get the error: Cannot convert type 'string' to 'T?'
有没有办法解决这个问题?我对使用泛型创建方法不是很熟悉.
Is there a way around this? I am not very familiar with creating methods using generics.
推荐答案
要记住的另一件事是字符串本身可能为空.
Another thing to keep in mind is that the string itself might be null.
public static Nullable<T> ToNullable<T>(this string s) where T: struct
{
Nullable<T> result = new Nullable<T>();
try
{
if (!string.IsNullOrEmpty(s) && s.Trim().Length > 0)
{
TypeConverter conv = TypeDescriptor.GetConverter(typeof(T));
result = (T)conv.ConvertFrom(s);
}
}
catch { }
return result;
}
这篇关于将字符串转换为可空类型(int、double 等...)的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
本文标题为:将字符串转换为可空类型(int、double 等...)


- 在 C# 中异步处理项目队列 2022-01-01
- 带问号的 nvarchar 列结果 2022-01-01
- C# 通过连接字符串检索正确的 DbConnection 对象 2022-01-01
- 在 LINQ to SQL 中使用 contains() 2022-01-01
- CanBeNull和ReSharper-将其用于异步任务? 2022-01-01
- 是否可以在 .Net 3.5 中进行通用控件? 2022-01-01
- Windows 喜欢在 LINUX 中使用 MONO 进行服务开发? 2022-01-01
- 为什么 C# 中的堆栈大小正好是 1 MB? 2022-01-01
- 使用 rss + c# 2022-01-01
- Azure Active Directory 与 MVC,客户端和资源标识同一 2022-01-01