dynamic取属性及添加属性

C#获取dynamic(动态)实体的属性值

复制代码
List<student> item= conn.Query<student>($"select * from 表  where id=123 ").ToList();
    foreach (System.Reflection.PropertyInfo p in item.GetType().GetProperties())
                {
                    Console.WriteLine(p.Name+ " :"+p.GetValue(item, null));
                }
     
    class student{
    public string id{get;set;}
    public string name{get;set;}
    public string sex{get;set;}
    }
复制代码

当我们需要遍历动态一个实体想要知道某个字段有没有值时,我们可以这样来写

复制代码
List<dynamic> result = conn.Query($"select * from 表 where id='123'").ToList();
            foreach (KeyValuePair<string, object> col in result[0])
            {
                string aa = col.Key;//属性
                string bb = col.Value.ToString();//值
                if (!string.IsNullOrWhiteSpace(col.Value.ToString()))
                {

                }
            }
复制代码

 

 

dynamic集合动态添加属性

复制代码
List<dynamic> list = conn.Query(srhsql, p).ToList(); //查出数据
 List<dynamic> tmp = new List<dynamic>();
 foreach (var row in list)
{
                        dynamic info = new System.Dynamic.ExpandoObject();
                        var dic = (IDictionary<string, object>)info;
                        foreach (KeyValuePair<string, object> col in row)
                        {
                            dic.Add(col);
                        }
                        dic.Add("名称", "值");
                        tmp.Add(info);
                    }
                    list = tmp;}
复制代码

 

 

原文链接:

https://www.cnblogs.com/leebokeyuan/p/14128860.html

https://blog.csdn.net/qq_39569480/article/details/104480012

posted @ 2022-12-09 11:46  人生为卒  阅读(1766)  评论(0)    收藏  举报