生成Csv格式的字符串

using System;
using System.Collections.Generic;
using System.Linq;
using System.Reflection;
using System.Text;

namespace Comon
{
    public class CsvUtil
    {
        /// <summary>
        ///     生成Csv格式的字符串
        /// </summary>
        /// <typeparam name="T">数据源类型</typeparam>
        /// <param name="sourceDate">数据源</param>
        /// <param name="generateFileldDict">需要生成到Csv格式字段及描述</param>
        /// <returns></returns>
        public static string GenerateCsvFormate<T>(IList<T> sourceDate, IDictionary<string, string> generateFileldDict)
            where T : class, new()
        {
            if (sourceDate == null)
            {
                throw new ArgumentNullException(nameof(sourceDate));
            }

            Type type = typeof(T);
            PropertyInfo[] propertyInfos = type.GetProperties();

            IList<string> fieldValueList = new List<string>(generateFileldDict.Count);

            StringBuilder builder = new StringBuilder();

            foreach (var filedName in generateFileldDict.Values)
            {
                fieldValueList.Add(filedName);
            }
            builder.AppendLine(string.Join(",", fieldValueList));

            foreach (var item in sourceDate)
            {
                fieldValueList.Clear();
                foreach (var field in generateFileldDict.Keys)
                {
                    PropertyInfo property = propertyInfos.FirstOrDefault(c => c.Name == field);
                    if (property != null)
                    {
                        var fieldValue = property.GetValue(item).ToString();
                        fieldValueList.Add(fieldValue);
                    }
                }
                builder.AppendLine(string.Join(",", fieldValueList));
            }
            return builder.ToString();
        }
    }
}

  

转载于:https://www.cnblogs.com/tangchun/p/10482632.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值