在AutoMapper问题中使用string.Split()

时间:2019-02-25 00:50:56

标签: automapper asp-net-core-spa-services

我有一个ASP .Net核心应用程序。我只是想让我的AutoMapper配置为按照以下配置将以逗号分隔的字符串转换为字符串列表:

configuration.CreateMap<Job, JobDto>()
                .ForMember(dto => dto.Keywords, options => options.MapFrom(entity => entity.Keywords.Split(',').ToList()))

由于某种原因,它无法编译,并给我以下错误:

  

表达式树可能不包含使用以下内容的调用或调用   可选参数

我看不到为什么出现此错误。我很确定我之前在其他项目中都做到了这一点,而没有任何此类错误。

4 个答案:

答案 0 :(得分:1)

正如错误所说,Split函数有一个可选参数。它的完整签名是这样的(选项是可选的)

public string[] Split(string separator, StringSplitOptions options = StringSplitOptions.None)

当您尝试在表达式树中使用具有默认值的函数时,它会给您错误。 要修复它,很简单,只需自己传递可选参数即可。 ( StringSplitOptions.None ) 因此,只需将其更改为:

entity.Keywords.Split(',' , StringSplitOptions.None).ToList()

答案 1 :(得分:0)

我有同样的问题。我不知道这是否是一个问题。无论如何,我找到了解决方法。

 CreateMap<Category, GetCategoryRest>()
                .ForMember(dest => dest.Words, 
                    opt => opt.MapFrom(src => ToWordsList(src.Words)));

 private static List<string> ToWordsList(string words)
 {
   return string.IsNullOrWhiteSpace(words) ? new List<string>() : words.Split(",").ToList();
 }

保证AutoMapper始终具有List。不过,我还是很困惑。在我的Startup.cs中,我定义AutoMapper允许list的值为空。

Mapper.Initialize(cfg => {
 cfg.AllowNullCollections = true;
}

Category.WordsstringGetCategoryRest.WordsList<string>

AutoMapper版本:8.1.1, AutoMapper.Microsoft.DependencyInjection:6.1.1

答案 2 :(得分:-1)

这是完全正确的。

引发错误是因为正在创建的表达式树将包含一些更复杂的逻辑,例如.Split(',').ToList(),这不是可访问的属性或方法,仅支持顶级的反射对象属性和方法(例如类MemberInfo)。

表达式树不支持属性链接,深层调用(.obj1property.obj2property)和扩展方法,就像在此.ToList()调用中一样。

我的解决方案是这样的:

// Execute a custom function to the source and/or destination types after member mapping
configuration.CreateMap<Job, JobDto>()
  .AfterMap((dto,jobDto)=>jobDto.Keywords = dto.Keywords.Split(',').ToList());

答案 3 :(得分:-1)

使用 .AfterMap

 CreateMap<src, dto>()
                .ForMember(src =>src.Categories,options=> options.Ignore())
                .AfterMap((src, dto) => { dto.Categories.AddRange(src.Categories.Split(",").ToList()); })
                .ReverseMap()
                .ForMember(src => src.Categories, option => option.MapFrom(dto => string.Join(",", dto.Categories)));