首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

C# -将属性路径列表及其值动态转换为类对象

在C#中,可以使用反射和递归的方式将属性路径列表及其值动态转换为类对象。以下是一个示例代码,展示了如何实现这个功能:

代码语言:txt
复制
using System;
using System.Reflection;

public class MyClass
{
    public string Name { get; set; }
    public int Age { get; set; }
    public Address Address { get; set; }
}

public class Address
{
    public string Street { get; set; }
    public string City { get; set; }
}

public static class ObjectConverter
{
    public static T ConvertToObject<T>(string[] propertyPaths, object[] propertyValues) where T : class, new()
    {
        if (propertyPaths.Length != propertyValues.Length)
        {
            throw new ArgumentException("The number of property paths and property values must be equal.");
        }

        T obj = new T();
        Type objectType = typeof(T);

        for (int i = 0; i < propertyPaths.Length; i++)
        {
            SetProperty(objectType, obj, propertyPaths[i], propertyValues[i]);
        }

        return obj;
    }

    private static void SetProperty(Type objectType, object obj, string propertyPath, object propertyValue)
    {
        string[] properties = propertyPath.Split('.');
        PropertyInfo propertyInfo = objectType.GetProperty(properties[0]);

        if (propertyInfo == null)
        {
            throw new ArgumentException($"Property '{properties[0]}' does not exist in type '{objectType.Name}'.");
        }

        if (properties.Length > 1)
        {
            object nestedObj = propertyInfo.GetValue(obj);
            if (nestedObj == null)
            {
                nestedObj = Activator.CreateInstance(propertyInfo.PropertyType);
                propertyInfo.SetValue(obj, nestedObj);
            }

            SetProperty(propertyInfo.PropertyType, nestedObj, string.Join(".", properties, 1, properties.Length - 1), propertyValue);
        }
        else
        {
            if (propertyInfo.PropertyType != propertyValue.GetType())
            {
                throw new ArgumentException($"Value type '{propertyValue.GetType().Name}' does not match property type '{propertyInfo.PropertyType.Name}'.");
            }

            propertyInfo.SetValue(obj, propertyValue);
        }
    }
}

public class Program
{
    public static void Main()
    {
        string[] propertyPaths = { "Name", "Age", "Address.Street", "Address.City" };
        object[] propertyValues = { "John Doe", 30, "123 Main St", "New York" };

        MyClass obj = ObjectConverter.ConvertToObject<MyClass>(propertyPaths, propertyValues);

        Console.WriteLine($"Name: {obj.Name}");
        Console.WriteLine($"Age: {obj.Age}");
        Console.WriteLine($"Street: {obj.Address.Street}");
        Console.WriteLine($"City: {obj.Address.City}");
    }
}

在上面的示例代码中,我们定义了一个MyClass类和一个Address类作为示例。然后,我们创建了一个ObjectConverter类,其中包含了ConvertToObject方法,该方法接受一个属性路径列表和一个属性值列表,并将其转换为指定类型的类对象。

ConvertToObject方法中,我们使用了反射来获取和设置类对象的属性。首先,我们根据属性路径中的第一个属性名获取对应的PropertyInfo对象,然后根据属性路径的长度判断是否还有嵌套属性。如果有嵌套属性,则递归调用SetProperty方法来处理嵌套属性。如果没有嵌套属性,则根据属性值的类型将属性值设置到类对象的对应属性上。

Main方法中,我们创建了一个属性路径列表和属性值列表作为示例数据,并调用ConvertToObject方法来将其转换为MyClass对象。然后,我们输出了转换后的对象的属性值。

这个功能适用于需要根据动态数据创建类对象的场景,例如解析JSON或XML数据并将其映射到类对象中。

推荐的腾讯云相关产品:无

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

【深入浅出C#】章节 2:数据类型和变量:类型转换和类型推断

类型转换和类型推断是C#编程中重要的概念和技术,它们在处理数据和变量时起到关键作用。类型转换允许我们在不同数据类型之间进行转换,以便进行正确的计算和操作。它可以帮助我们处理数据的精度、范围和表达需求。而类型推断则使代码更加简洁和可读,通过自动推断变量的类型,减少了冗余的代码和类型声明。 在《类型转换和类型推断》这篇文章中,我们将深入探讨类型转换的不同方式,包括显式类型转换和隐式类型转换,以及装箱和拆箱的概念。我们还将讨论类型推断的实际应用,包括使用var关键字和匿名类型的场景,以及动态类型的灵活性。

01
  • c#实战教程_ps初学者入门视频

    大家好,又见面了,我是你们的朋友全栈君。 C#基础教程-c#实例教程,适合初学者。 第一章 C#语言基础 本章介绍C#语言的基础知识,希望具有C语言的读者能够基本掌握C#语言,并以此为基础,能够进一步学习用C#语言编写window应用程序和Web应用程序。当然仅靠一章的内容就完全掌握C#语言是不可能的,如需进一步学习C#语言,还需要认真阅读有关C#语言的专著。 1.1 C#语言特点 Microsoft.NET(以下简称.NET)框架是微软提出的新一代Web软件开发模型,C#语言是.NET框架中新一代的开发工具。C#语言是一种现代、面向对象的语言,它简化了C++语言在类、命名空间、方法重载和异常处理等方面的操作,它摒弃了C++的复杂性,更易使用,更少出错。它使用组件编程,和VB一样容易使用。C#语法和C++和JAVA语法非常相似,如果读者用过C++和JAVA,学习C#语言应是比较轻松的。 用C#语言编写的源程序,必须用C#语言编译器将C#源程序编译为中间语言(MicroSoft Intermediate Language,MSIL)代码,形成扩展名为exe或dll文件。中间语言代码不是CPU可执行的机器码,在程序运行时,必须由通用语言运行环境(Common Language Runtime,CLR)中的既时编译器(JUST IN Time,JIT)将中间语言代码翻译为CPU可执行的机器码,由CPU执行。CLR为C#语言中间语言代码运行提供了一种运行时环境,C#语言的CLR和JAVA语言的虚拟机类似。这种执行方法使运行速度变慢,但带来其它一些好处,主要有:  通用语言规范(Common Language Specification,CLS):.NET系统包括如下语言:C#、C++、VB、J#,他们都遵守通用语言规范。任何遵守通用语言规范的语言源程序,都可编译为相同的中间语言代码,由CLR负责执行。只要为其它操作系统编制相应的CLR,中间语言代码也可在其它系统中运行。  自动内存管理:CLR内建垃圾收集器,当变量实例的生命周期结束时,垃圾收集器负责收回不被使用的实例占用的内存空间。不必象C和C++语言,用语句在堆中建立的实例,必须用语句释放实例占用的内存空间。也就是说,CLR具有自动内存管理功能。  交叉语言处理:由于任何遵守通用语言规范的语言源程序,都可编译为相同的中间语言代码,不同语言设计的组件,可以互相通用,可以从其它语言定义的类派生出本语言的新类。由于中间语言代码由CLR负责执行,因此异常处理方法是一致的,这在调试一种语言调用另一种语言的子程序时,显得特别方便。  增加安全:C#语言不支持指针,一切对内存的访问都必须通过对象的引用变量来实现,只允许访问内存中允许访问的部分,这就防止病毒程序使用非法指针访问私有成员。也避免指针的误操作产生的错误。CLR执行中间语言代码前,要对中间语言代码的安全性,完整性进行验证,防止病毒对中间语言代码的修改。  版本支持:系统中的组件或动态联接库可能要升级,由于这些组件或动态联接库都要在注册表中注册,由此可能带来一系列问题,例如,安装新程序时自动安装新组件替换旧组件,有可能使某些必须使用旧组件才可以运行的程序,使用新组件运行不了。在.NET中这些组件或动态联接库不必在注册表中注册,每个程序都可以使用自带的组件或动态联接库,只要把这些组件或动态联接库放到运行程序所在文件夹的子文件夹bin中,运行程序就自动使用在bin文件夹中的组件或动态联接库。由于不需要在注册表中注册,软件的安装也变得容易了,一般将运行程序及库文件拷贝到指定文件夹中就可以了。  完全面向对象:不象C++语言,即支持面向过程程序设计,又支持面向对象程序设计,C#语言是完全面向对象的,在C#中不再存在全局函数、全局变量,所有的函数、变量和常量都必须定义在类中,避免了命名冲突。C#语言不支持多重继承。 1.2 编写控制台应用程序 使用SDK命令行工具编写控制台程序 第一个程序总是非常简单的,程序首先让用户通过键盘输入自己的名字,然后程序在屏幕上打印一条欢迎信息。程序的代码是这样的: using System;//导入命名空间。//为C#语言新增解释方法,解释到本行结束 class Welcome//类定义,类的概念见下一节 { /*解释开始,和C语言解释用法相同 解释结束*/ static void Main()//主程序,程序入口函数,必须在一个类中定义 { Console.WriteLine(“请键入你的姓名:”);//控制台输出字符串 Console.ReadLine();//从键盘读入数据,输入回车结束 Console.WriteLine(“欢迎!”); } } 可以用任意一种文本编辑软件完成上述代码的编写,然后把文件存盘,假设文件名叫做welcome.c

    01

    refseq数据库的特点_eureka如何剔除服务

    在SCOTT HANSELMAN 博客上看到一个好东西《Exploring refit, an automatic type-safe REST library for .NET Standard》,他推荐了一个.NET标准1.4 的自动类型安全的REST库refit。 refit 类似于Java的Retrofit,是一套RESTful架构的.NET客户端实现,基于特性,提供把REST API返回的数据转化为(Plain Ordinary C# Object,简单C#对象),POCO to JSON,网络请求(POST,GET,PUT,DELETE等)封装,内部封装使用HttpClient,前者专注于接口的封装,后者专注于网络请求的高效,二者分工协作。我们的应用程序通过 refit请求网络,实际上是使用 refit接口层封装请求参数、Header、Url 等信息,之后由 HttpClient完成后续的请求操作,在服务端返回数据之后,HttpClient将原始的结果交给 refit,后者根据用户的需求对结果进行解析的过程。

    03
    领券