Для преобразования Linq в DataTable я использую следующий метод расширения ( Взято из Stackoverflow)
Linq to DataTable
public static DataTable ToDataTable<T>(this IEnumerable<T> items)
{
DataTable table = new DataTable(typeof(T).Name);
PropertyInfo[] props = typeof(T).GetProperties(BindingFlags.Public |
BindingFlags.Instance);
foreach (var prop in props)
{
Type propType = prop.PropertyType;
// Is it a nullable type? Get the underlying type
if (propType.IsGenericType &&
propType.GetGenericTypeDefinition().Equals(typeof(Nullable<>)))
propType = new NullableConverter(propType).UnderlyingType;
table.Columns.Add(prop.Name, propType);
}
foreach (var item in items)
{
var values = new object[props.Length];
for (var i = 0; i < props.Length; i++)
values[i] = props[i].GetValue(item, null);
table.Rows.Add(values);
}
return table;
}
WriteXml
PersonDB.PersonDataContext con = new PersonDB.PersonDataContext();
DataTable tb = new DataTable();
tb = con.Persons.ToDataTable();
tb.WriteXml(@"d:\temp\Person.xml");
Вопрос
Метод расширения создает файл XML, но для значений NULL в файле XML не создается элемент. В нем говорится, что если поле Commission равно нулю, то элемент комиссии отсутствует в генерации Xml.
Я хочу вставить элемент с пустой строкой для нулевых значений (тип ссылки) и (0,00) для десятичных чисел и (0) для целых чисел. Где мне нужно внести изменения?