здесь есть способ сделать это
varFactor <- factor(letters[1:15])
varFactor <- varFactor[1:5]
varFactor <- varFactor[drop=T]
Для этого можно использовать отражение .
Ваш сценарий может выглядеть примерно так:
static void Main(string[] args)
{
var list = new List<Mammal>();
list.Add(new Person { Name = "Filip", DOB = DateTime.Now });
list.Add(new Person { Name = "Peter", DOB = DateTime.Now });
list.Add(new Person { Name = "Goran", DOB = DateTime.Now });
list.Add(new Person { Name = "Markus", DOB = DateTime.Now });
list.Add(new Dog { Name = "Sparky", Breed = "Unknown" });
list.Add(new Dog { Name = "Little Kid", Breed = "Unknown" });
list.Add(new Dog { Name = "Zorro", Breed = "Unknown" });
foreach (var item in list)
Console.WriteLine(item.Speek());
list = ReCalculateDOB(list);
foreach (var item in list)
Console.WriteLine(item.Speek());
}
Где вы хотите пересчитать дни рождения всех млекопитающих. И Реализации вышеупомянутого выглядят следующим образом:
internal interface Mammal
{
string Speek();
}
internal class Person : Mammal
{
public string Name { get; set; }
public DateTime DOB { get; set; }
public string Speek()
{
return "My DOB is: " + DOB.ToString() ;
}
}
internal class Dog : Mammal
{
public string Name { get; set; }
public string Breed { get; set; }
public string Speek()
{
return "Woff!";
}
}
Итак, в основном, что вам нужно сделать, это использовать Relfection, который представляет собой механизм для проверки типов и получения свойств типов и других подобных вещей во время выполнения. Вот пример того, как вы добавляете 10 дней к указанным выше DOB для каждого Mammal, получившего DOB.
static List<Mammal> ReCalculateDOB(List<Mammal> list)
{
foreach (var item in list)
{
var properties = item.GetType().GetProperties();
foreach (var property in properties)
{
if (property.PropertyType == typeof(DateTime))
property.SetValue(item, ((DateTime)property.GetValue(item, null)).AddDays(10), null);
}
}
return list;
}
Просто помните, что использование отражения может быть медленным, и в целом медленным.
Однако вверху будет напечатано следующее:
My DOB is: 2010-03-22 09:18:12
My DOB is: 2010-03-22 09:18:12
My DOB is: 2010-03-22 09:18:12
My DOB is: 2010-03-22 09:18:12
Woff!
Woff!
Woff!
My DOB is: 2010-04-01 09:18:12
My DOB is: 2010-04-01 09:18:12
My DOB is: 2010-04-01 09:18:12
My DOB is: 2010-04-01 09:18:12
Woff!
Woff!
Woff!
class HasDateTimes
{
public DateTime Foo { get; set; }
public string NotWanted { get; set; }
public DateTime Bar { get { return DateTime.MinValue; } }
}
static void Main(string[] args)
{
foreach (var propertyInfo in
from p in typeof(HasDateTimes).GetProperties()
where Equals(p.PropertyType, typeof(DateTime)) select p)
{
Console.WriteLine(propertyInfo.Name);
}
}
Для очень быстрых ответов и указателей на этот вопрос, и если у вас есть PowerShell (Vista / Windows 7, Windows 2008 уже установлена), вы можете просто запустите консоль и для DateTime, например do
Get-Date | Get-Member
Что выведет список членов экземпляра DateTime. Вы также можете посмотреть на статические элементы:
Get-Date | Get-Member -Static
Если вас беспокоит влияние отражения на производительность, вас может заинтересовать Fasterflect , библиотека для упрощения запросов и доступа к членам. и быстрее.
Например, код MaxGuernseyIII может быть переписан с использованием Fasterflect следующим образом:
var query = from property in typeof(HasDateTimes).Properties()
where property.Type() == typeof(DateTime)
select p;
Array.ForEach( query.ToArray(), p => Console.WriteLine( p.Name ) );
Fasterflect использует упрощенную генерацию кода для ускорения доступа (в 2-5 раз или с почти родной скоростью, если вы кешируете и вызывать сгенерированные делегаты напрямую). Запросы участников обычно проще и удобнее, но не быстрее. Обратите внимание, что эти числа не включают значительные начальные накладные расходы на JIT-компиляцию сгенерированного кода, поэтому прирост производительности становится заметным только при повторных доступах.
Отказ от ответственности: я участвую в проекте.
Это называется отражением.
var t = this;
var props = t.GetType().GetProperties();
foreach (var prop in props)
{
if (prop.PropertyType == typeof(DateTime))
{
//do stuff like prop.SetValue(t, DateTime.Now, null);
}
}
найдите отражение, но в основном вы делаете это
obj.GetType (). GetProperties (.. Instance | ..Public), и вы получаете список определенных свойств .. проверьте тип значения свойства и сравните это typeof (DateTime).