Как получить все свойства из класса / объекта C # [duplicate]

Я разработал компонент Java для преобразования данного числа в слова. Все, что вам нужно сделать - просто скопировать весь класс из Java-программы для преобразования чисел в слова и вставить их в свой проект.

Просто вызовите его, как показано ниже

  Слова w = Words.getInstance (1234567);  System.out.println (w.getNumberInWords ());   

Моя программа поддерживает до 10 миллионов. Если вы хотите, вы все равно можете расширить это. Только ниже примера выведите

  2345223 = Двадцать три Лаха Четыредцать пять тысяч Две сотни Двадцать три 9999999 = Девяносто девять Лах Девяносто девять Девять Сто девяносто девять 199 = Сто девяносто девять Десять [10]  d2] 

Спасибо

Santhosh

468
задан nawfal 16 June 2013 в 09:37
поделиться

9 ответов

Вы можете использовать отражение.

Type typeOfMyObject = myObject.GetType();
PropertyInfo[] properties =typeOfMyObject.GetProperties();
6
ответ дан Daan 15 August 2018 в 15:15
поделиться

Основываясь на ответе @ MarcGravell, вот версия, которая работает в Unity C #.

ObjectsClass foo = this;
foreach(var prop in foo.GetType().GetProperties()) {
    Debug.Log("{0}={1}, " + prop.Name + ", " + prop.GetValue(foo, null));
}
14
ответ дан Jacksonkr 15 August 2018 в 15:15
поделиться

Вы можете использовать Reflection для этого: (из моей библиотеки - это получает имена и значения)

public static Dictionary<string, object> DictionaryFromType(object atype)
{
    if (atype == null) return new Dictionary<string, object>();
    Type t = atype.GetType();
    PropertyInfo[] props = t.GetProperties();
    Dictionary<string, object> dict = new Dictionary<string, object>();
    foreach (PropertyInfo prp in props)
    {
        object value = prp.GetValue(atype, new object[]{});
        dict.Add(prp.Name, value);
    }
    return dict;
}

Эта вещь не будет работать для свойств с индексом - для этого (она становится громоздкой ):

public static Dictionary<string, object> DictionaryFromType(object atype, 
     Dictionary<string, object[]> indexers)
{
    /* replace GetValue() call above with: */
    object value = prp.GetValue(atype, ((indexers.ContainsKey(prp.Name)?indexers[prp.Name]:new string[]{});
}

Кроме того, чтобы получить только общедоступные свойства: ( см. MSDN в BindingFlags enum )

/* replace */
PropertyInfo[] props = t.GetProperties();
/* with */
PropertyInfo[] props = t.GetProperties(BindingFlags.Public)

Это работает с анонимными типами, слишком! Чтобы просто получить имена:

public static string[] PropertiesFromType(object atype)
{
    if (atype == null) return new string[] {};
    Type t = atype.GetType();
    PropertyInfo[] props = t.GetProperties();
    List<string> propNames = new List<string>();
    foreach (PropertyInfo prp in props)
    {
        propNames.Add(prp.Name);
    }
    return propNames.ToArray();
}

И это примерно то же самое только для значений, или вы можете использовать:

GetDictionaryFromType().Keys
// or
GetDictionaryFromType().Values

Но это немного медленнее, я бы представьте себе.

61
ответ дан JHobern 15 August 2018 в 15:15
поделиться
  • 1
    ... но atype.GetProperty (prp.Name) собирается вернуть prp? – Marc Gravell♦ 10 April 2009 в 10:37
  • 2
    О, ты прав! D'о. – Lucas Jones 10 April 2009 в 10:43
  • 3
    Я исправил это сейчас. – Lucas Jones 10 April 2009 в 10:57
  • 4
  • 5
    не искал код, я искал объяснения для размышлений и ничего себе, так высоко оценил! Сделайте это родовым, и вы могли бы просто сказать, что ваша программа обладает суперспособностями;) – KDOT 18 March 2016 в 17:47

Вы можете использовать пространство имен System.Reflection с помощью метода Type.GetProperties():

PropertyInfo[] propertyInfos;
propertyInfos = typeof(MyClass).GetProperties(BindingFlags.Public|BindingFlags.Static);
20
ответ дан Jon Limjap 15 August 2018 в 15:15
поделиться

Здесь улучшен ответ @lucasjones. Я включил улучшения, упомянутые в разделе комментариев после его ответа. Я надеюсь, что кто-то найдет это полезным.

public static string[] GetTypePropertyNames(object classObject,  BindingFlags bindingFlags)
{
    if (classObject == null)
    {
        throw new ArgumentNullException(nameof(classObject));
    }

        var type = classObject.GetType();
        var propertyInfos = type.GetProperties(bindingFlags);

        return propertyInfos.Select(propertyInfo => propertyInfo.Name).ToArray();
 }
3
ответ дан Kjartan 15 August 2018 в 15:15
поделиться

Это мое решение

public class MyObject
{
    public string value1 { get; set; }
    public string value2 { get; set; }

    public PropertyInfo[] GetProperties()
    {
        try
        {
            return this.GetType().GetProperties();
        }
        catch (Exception ex)
        {

            throw ex;
        }
    }

    public PropertyInfo GetByParameterName(string ParameterName)
    {
        try
        {
            return this.GetType().GetProperties().FirstOrDefault(x => x.Name == ParameterName);
        }
        catch (Exception ex)
        {

            throw ex;
        }
    }

    public static MyObject SetValue(MyObject obj, string parameterName,object parameterValue)
    {
        try
        {
            obj.GetType().GetProperties().FirstOrDefault(x => x.Name == parameterName).SetValue(obj, parameterValue);
            return obj;
        }
        catch (Exception ex)
        {
            throw ex;
        }
    }
}
31
ответ дан Pang 15 August 2018 в 15:15
поделиться
  • 1
    – Matthew Haugen 24 July 2014 в 04:42
  • 2
    Мне это нравится, потому что это (почти) единственный ответ, который не включает слово reflection . – user 28 July 2015 в 15:41
  • 3
    Но все же использует отражение. – GGG 12 April 2016 в 21:51
  • 4
    я думаю, это намного лучше pObject.GetType (). GetProperties (). Выберите (p = & gt; p.Name) – Disappointed 9 June 2016 в 16:18

Отражение; для экземпляра:

obj.GetType().GetProperties();

для типа:

typeof(Foo).GetProperties();

, например:

class Foo {
    public int A {get;set;}
    public string B {get;set;}
}
...
Foo foo = new Foo {A = 1, B = "abc"};
foreach(var prop in foo.GetType().GetProperties()) {
    Console.WriteLine("{0}={1}", prop.Name, prop.GetValue(foo, null));
}

После обратной связи ...

  • Чтобы получить значение статических свойств, передайте null в качестве первого аргумента в GetValue
  • . Чтобы просмотреть непубличные свойства, используйте (например) GetProperties(BindingFlags.Public | BindingFlags.NonPublic | BindingFlags.Instance) (который возвращает все свойства public / private экземпляра).
630
ответ дан Robert Harvey 15 August 2018 в 15:15
поделиться
  • 1
    Для полноты есть также ComponentModel, открытый TypeDescriptor.GetProperties (...) - который позволяет динамические свойства времени выполнения (отражение фиксировано во время компиляции). – Marc Gravell♦ 10 April 2009 в 10:38
  • 2
  • 3
    Заявление foreach, которое вы показываете, даже работает из класса, в котором вы хотите получить свойства :) – halfpastfour.am 24 January 2012 в 11:27
  • 4
    Мне было непонятно, как указываются дополнительные комментарии, но использование всех трех флагов также дает вам свойства internal. Может быть, я единственный, кто повесил трубку на синтаксисе private / non-public? – brichins 9 August 2013 в 00:39
  • 5
    @Tadej, какие рамки вы нацеливаете? если вы используете ядро ​​.NET, вам необходимо убедиться, что вы указали директиву using System.Reflection и System.Reflection.TypeExtensions - это обеспечивает отсутствие поверхности API через методы расширения – Marc Gravell♦ 17 May 2017 в 09:18

Я также сталкиваюсь с таким требованием.

Из этого обсуждения я получил еще одну идею,

Obj.GetType().GetProperties()[0].Name

Это также показывает имя свойства.

Obj.GetType().GetProperties().Count();

, показывающий количество свойств.

Спасибо всем. Это приятное обсуждение.

3
ответ дан Singaravelan 15 August 2018 в 15:15
поделиться
31
ответ дан Pang 5 September 2018 в 14:20
поделиться
Другие вопросы по тегам:

Похожие вопросы: