c# - CSharpScript.EvaluateAsync 无法识别枚举
问题描述
我正在使用CSharpScript.EvaluateAsync
从字符串生成谓词。使用 string 和 int 变量可以正常工作,但是如果我尝试在字符串中传入枚举变量以进行转换,则会引发错误:
消息“(1,26):错误CS0103:当前上下文中不存在名称'状态'”字符串
这是独立的复制品:
using System;
using System.Collections.Generic;
using System.Linq;
using Microsoft.CodeAnalysis.CSharp.Scripting;
using Microsoft.CodeAnalysis.Scripting;
namespace PredicateParser
{
class Program
{
static void Main(string[] args)
{
var albums = new List<Album>
{
new Album { Quantity = 10, Artist = "Betontod", Title = "Revolution", Status = Status.Offline},
new Album { Quantity = 50, Artist = "The Dangerous Summer", Title = "The Dangerous Summer", Status = Status.Offline },
new Album { Quantity = 200, Artist = "Depeche Mode", Title = "Spirit", Status = Status.Online },
};
var albumFilter1 = "album => album.Quantity > 20 && album.Quantity < 200"; //works fine
var albumFilter2 = "album => album.Status == Status.Online"; //Throws exception
var predicate1 = CreatePredicate<Album>(albumFilter1);
var predicate2 = CreatePredicate<Album>(albumFilter2);
var filteredAlbums1 = albums.Where(predicate1).ToList();
var filteredAlbums2 = albums.Where(predicate2).ToList();
}
public static Func<T, bool> CreatePredicate<T>(string command)
{
var options = ScriptOptions.Default.AddReferences(typeof(T).Assembly);
Func<T, bool> predicate = CSharpScript.EvaluateAsync<Func<T, bool>>(command, options).Result;
return predicate;
}
}
public class Album
{
public int Quantity { get; set; }
public string Title { get; set; }
public string Artist { get; set; }
public Status Status { get; set; }
}
public enum Status
{
Online,
Offline
}
}
我怎样才能让它与枚举一起工作?
解决方案
var options = ScriptOptions.Default.AddReferences(typeof(T).Assembly).AddImports(nameof(PredicateParser));
您忘记添加“使用命名空间”:)
推荐阅读
- c# - FlowDocumentReader - 将回车换行字符添加到没有的文本末尾
- python - 如果 add_roles 和 remove_roles 不会导致更改,它们是否会“命中”不和谐服务?
- laravel - 使用 Laravel Eloquent 模型显示数据库中的数据
- python - 如何从python中的字典列表中轻松获取值列表?
- r - R 操作特定序列的字符向量
- android - 删除Android中仅创建任务但活动从不聚焦的后台活动任务
- python - 在 Flask 中捕获 API 返回的变量
- google-sheets - 如何在 Google 表格中将不连续范围输入到 SUMIF
- azure - 如何使用 Java 和 Gradle 创建 Azure Durable Functions Orchestration 项目?
- java - 自动舍入 SQL d