首页 > 其他分享 >NetCore DynamicExpresso 动态表达式使用例子

NetCore DynamicExpresso 动态表达式使用例子

时间:2024-09-13 10:36:52浏览次数:9  
标签:DynamicExpresso Console NetCore CustomerID Interpreter var new public 表达式

Simple.cs 简单使用例子
using DynamicExpresso;

namespace DynamicExpressoDemo
{
    class Customer { public string Name { get; set; } }

    public class Simple
    {
        public static void Test()
        {
            // 返回结果
            Interpreter target1 = new Interpreter();
            double result1 = target1.Eval<double>("Math.Min(x, y) + 5", new Parameter("x", typeof(double), 1), new Parameter("y", typeof(double), 2));
            Console.WriteLine($"result:{result1}");// 输出:6

            // 定义变量并赋值
            var target2 = new Interpreter().SetVariable("myVar", 23);
            var result2 = target2.Eval("myVar + 10");
            Console.WriteLine($"result:{result2}");// 输出:33

            // 动态参数
            var target3 = new Interpreter();
            var parameters = new[] { new Parameter("x", 23), new Parameter("y", 7) };
            var result3 = target3.Eval("x + y", parameters);
            Console.WriteLine($"result:{result3}");// 输出:30

            var target = new Interpreter();
            target.SetVariable("a", new Customer { Name = "AA" });
            target.SetVariable("b", new Customer { Name = "BB" });
            Console.WriteLine(target.Eval("a.Name"));// 输出:AA
            Console.WriteLine(target.Eval("b.Name")); // 输出:BB
        }
    }
}

QueryMemoryData.cs 查询内存数据例子

using DynamicExpresso;

namespace DynamicExpressoDemo
{
    class Trade
    {
        public int TradeID { get; set; }

        public string TradeTitle { get; set; }

        public DateTime Created { get; set; }

        public int CustomerID { get; set; }
    }

    public class QueryMemoryData
    {
        static Interpreter interpreter = new Interpreter();

        public static void Filter()
        {
            var tradeList = new List<Trade>()
            {
                new Trade() { TradeID = 1, TradeTitle = "交易1", Created = Convert.ToDateTime("2020/8/1"), CustomerID = 1 },
                new Trade() { TradeID = 2, TradeTitle = "交易2", Created = Convert.ToDateTime("2020/8/5"), CustomerID = 2 },
                new Trade() { TradeID = 3, TradeTitle = "交易3", Created = Convert.ToDateTime("2020/8/10"), CustomerID = 3 }
            };

            // 查询内存值
            string whereExpression = "(trade.CustomerID == 1 || trade.CustomerID == 2 || trade.CustomerID == 10) && trade.Created <= Convert.ToDateTime(\"2020-08-20\")"; 
            Func<Trade, bool> queryFunc = interpreter.ParseAsDelegate<Func<Trade, bool>>(whereExpression, "trade"); 
            var list = tradeList.Where(queryFunc).ToList();// list + DynamicExpresso

            foreach (var a in list)
            {
                a.TradeTitle = a.TradeTitle + "_update";// 更新内存值
                Console.WriteLine(a.ToString());
            }
        }
    }
}

 

 

标签:DynamicExpresso,Console,NetCore,CustomerID,Interpreter,var,new,public,表达式
From: https://www.cnblogs.com/chen1880/p/18411774

相关文章

  • SpEL 表达式注入
    SpEL表达式注入spel是什么SpEL(SpringExpressionLanguage),即Spring表达式语言,比JSP的EL更强大的一种表达式语言。特别是方法调用和基本的字符串模板功能。Spring框架的核心功能之一就是通过依赖注入的方式来管理Bean之间的依赖关系,而SpEl可以方便快捷的对ApplicationContext中......
  • 【C语言基础】数据类型、运算符和表达式
    1数据类型基本类型整型:短整型,基本整型,长整型字符型实型(浮点型):单精度型,双精度型枚举类型构造类型:是使用基本类型的数据或者使用已经构造好的数据类型,进行添加、设计构造出新的数据类型,使其设计的新构造类型满足待解决问题所需要的数据类型。数组类型结构体类型共用体类......
  • vue优点/插值表达式/强制绑定
    1.Vue.js的优点体积小:压缩后只有33k;更高的运行效率:基于虚拟DOM,一种可以预先通过JavaScript进行各种计算,把最终的DOM操作计算出来并优化的技术,由于这种DOM操作属于预处理操作,并没有真实的操作DOM,所以叫做虚拟DOM;双向数据绑定:让开发者不用再去操作DOM对象,把更多的精力投入到业务......
  • c++primer第五章循环和关系表达式学习笔记
    for循环简单for循环#include<iostream>usingnamespacestd;intmain(){//5.1inti;for(i=0;i<5;i++)cout<<"C++knowsloops.\n";cout<<"C++knowswhentostop.\n";return0;}for循环组成部分#......
  • C# .netcore NPOI库 实现报表的列自适应删减
    实际需求:业务上的一个需求,数据库表A中的B字段存放的是该条数据的一些标签,标签存在两级【即一级标签和二级标签】,现在要是实现将这些标签统计到报表中,一级标签作为表头,二级标签作为填充值。由于之前的报表每增加一个列都需要去数据库表中增加这个字段名称,然后代码中写统计逻辑,这......
  • 使用Java实现字符串中的表达式计算
    /***计算字符串表达式的值,不支持小数*<ul>*<li>加法('+')</li>*<li>减法('-')</li>*<li>乘法('*')</li>*<li>除法,保留两位小数('/')</li>*<li>取余,获取商('......
  • sql-server公用表表达式
    视图是作为数据库对象存储在数据库中的,如果这个结果集仅仅要使用一次,那么建立视图就太奢侈了。在SQLServer中,公共表表达式(CommonTableExpression,简称CTE)是一种临时的结果集,可以在一个查询块中多次引用。CTE可以用来简化复杂的查询,特别是那些需要多步操作或者递归查询的情况......
  • asp.netcore8 + vue3 + mysql 自用记账项目(四)项目部署
    一、生成后台api服务 1、在系统生成的Dockerfile基础上,添加时区标识FROMmcr.microsoft.com/dotnet/aspnet:8.0ASbaseENVTZAsia/ShanghaiRUNln-snf/usr/share/zoneinfo/$TZ/etc/localtime&&echo$TZ>/etc/timezoneWORKDIR/appEXPOSE80EXPOSE443FROMmcr.......
  • asp.netcore8 + vue3 + mysql 自用记账项目(二)环境搭建
    一、vue1、node.js安装安装node.js的攻略网上有很多,这里就不多做赘述,安装完成后,验证是否正常然后就是配置淘宝镜像加速,配置环境变量等操作。2、vue安装上面安装完node.js之后,就可以安装vue环境了,网上同样很多,需要注意的是,vue安装完成了,最好将webpack模版、vue-cli、vue-rout......
  • asp.netcore8 + vue3 + mysql 自用记账项目(三)功能开发
    一、前端前端使用vue3+vant4组件实现页面功能。 1、创建vue3项目各个操作分别是:选择创建模式?手动创建选择项目模块?Babel,Kouter,Wuex,CSSPreprocessors选择vue版本?3.0是否使用历史路由模式?是样式的写法?Less项目配置放在哪?package.json文件里是否保存本次......