0

0

C# 脚本和自动化方法 C#如何使用Roslyn Scripting API

煙雲

煙雲

发布时间:2026-02-26 06:59:34

|

246人浏览过

|

来源于php中文网

原创

roslyn scripting api 是 .net 提供的轻量级脚本执行能力,适合配置驱动逻辑、规则引擎、调试辅助和动态表达式求值等场景;需显式引用程序集、传入 globals 对象、注意类型可见性与异步限制。

c# 脚本和自动化方法 c#如何使用roslyn scripting api

什么是 Roslyn Scripting API,它适合做什么

Roslyn Scripting API 是 .NET 提供的轻量级脚本执行能力,不是编译整个项目,而是运行一段字符串形式的 C# 代码。它不替代完整编译流程,但适合配置驱动逻辑、规则引擎、调试辅助、自动化任务中的动态表达式求值等场景。

  • 不能直接引用未加载的程序集(比如 Newtonsoft.Json),必须显式添加引用
  • 不支持 async 方法体直接作为脚本主体(需包装为同步调用或使用 ScriptOptions 启用异步)
  • 脚本默认运行在沙箱中,无文件系统/网络访问权限,需手动注入依赖对象

如何安装和基础运行一个 C# 脚本

从 .NET 5 开始,Microsoft.CodeAnalysis.Scripting 已内置在 SDK 中,无需额外 NuGet 包;若用 .NET Core 3.1 或更早版本,需安装 Microsoft.CodeAnalysis.Scripting NuGet 包(注意匹配 SDK 版本)。

using Microsoft.CodeAnalysis.CSharp.Scripting;
using Microsoft.CodeAnalysis.Scripting;
<p>var result = await CSharpScript.EvaluateAsync<int>("1 + 2 * 3");
Console.WriteLine(result); // 输出 7</p>
  • EvaluateAsync 返回 Task<t></t>,必须 await.Result(后者可能死锁)
  • 类型参数 <int></int> 必须与脚本最后一行表达式的实际类型一致,否则抛 CompilationErrorException
  • 字符串内容不能含顶层类/命名空间声明,只允许表达式、语句块或单个方法体

如何传入变量和自定义类型到脚本中

脚本默认无法访问外部作用域变量,必须通过 globals 对象传入。该对象需是具体类实例,其公开字段/属性才能被脚本读写。

AutoIt3 中文帮助文档打包
AutoIt3 中文帮助文档打包

AutoIt v3 版本, 这是一个使用类似 BASIC 脚本语言的免费软件, 它设计用于 Windows GUI(图形用户界面)中进行自动化操作. 利用模拟键盘按键, 鼠标移动和窗口/控件的组合来实现自动化任务. 而这是其它语言不可能做到或无可靠方法实现的(比如VBScript和SendKeys). AutoIt 非常小巧, 完全运行在所有windows操作系统上.(thesnow注:现在已经不再支持win 9x,微软连XP都能放弃, 何况一个win 9x支持), 并且不需要任何运行库. AutoIt

下载
public class ScriptGlobals
{
    public int Count { get; set; } = 10;
    public string Prefix { get; set; } = "test";
}
<p>var globals = new ScriptGlobals();
var result = await CSharpScript.EvaluateAsync<string>(
"Prefix + Count.ToString()",
ScriptOptions.Default.WithReferences(typeof(Console).Assembly),
globals);</p>
  • WithReferences 必须显式加入所有脚本中用到的类型所在程序集(如 typeof(Console).Assembly
  • 若脚本中调用自定义类方法,该类必须是 public,且方法为 public 实例方法或静态方法
  • 不支持传入 dynamic 或匿名类型作 globals,编译会失败

常见错误和绕过限制的关键点

CS1685:找不到类型 —— 多数因漏掉 WithReferences 或引用了未导出的内部类型
CS0103:名称不存在 —— 变量未在 globals 中定义,或拼写与属性名不一致
OperationCanceledException:脚本执行超时,默认 30 秒,可设 ScriptOptions.Default.WithTimeout(TimeSpan.FromSeconds(60))

  • 脚本中不能用 using static,但可用 using(需在脚本开头写)
  • 若需多次执行相似脚本,复用 ScriptOptions 实例能提升性能(避免重复解析引用)
  • 编译错误信息藏在 CompilationErrorExceptionDiagnostics 属性里,建议捕获后打印以便调试

Roslyn Scripting 看似简单,但引用管理、类型可见性、异步上下文和超时控制这几处,稍不注意就会卡住几小时。尤其在容器或函数计算环境里,缺少调试输出时,Diagnostics 几乎是唯一线索。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
json数据格式
json数据格式

JSON是一种轻量级的数据交换格式。本专题为大家带来json数据格式相关文章,帮助大家解决问题。

448

2023.08.07

json是什么
json是什么

JSON是一种轻量级的数据交换格式,具有简洁、易读、跨平台和语言的特点,JSON数据是通过键值对的方式进行组织,其中键是字符串,值可以是字符串、数值、布尔值、数组、对象或者null,在Web开发、数据交换和配置文件等方面得到广泛应用。本专题为大家提供json相关的文章、下载、课程内容,供大家免费下载体验。

544

2023.08.23

jquery怎么操作json
jquery怎么操作json

操作的方法有:1、“$.parseJSON(jsonString)”2、“$.getJSON(url, data, success)”;3、“$.each(obj, callback)”;4、“$.ajax()”。更多jquery怎么操作json的详细内容,可以访问本专题下面的文章。

324

2023.10.13

go语言处理json数据方法
go语言处理json数据方法

本专题整合了go语言中处理json数据方法,阅读专题下面的文章了解更多详细内容。

81

2025.09.10

js 字符串转数组
js 字符串转数组

js字符串转数组的方法:1、使用“split()”方法;2、使用“Array.from()”方法;3、使用for循环遍历;4、使用“Array.split()”方法。本专题为大家提供js字符串转数组的相关的文章、下载、课程内容,供大家免费下载体验。

638

2023.08.03

js截取字符串的方法
js截取字符串的方法

js截取字符串的方法有substring()方法、substr()方法、slice()方法、split()方法和slice()方法。本专题为大家提供字符串相关的文章、下载、课程内容,供大家免费下载体验。

218

2023.09.04

java基础知识汇总
java基础知识汇总

java基础知识有Java的历史和特点、Java的开发环境、Java的基本数据类型、变量和常量、运算符和表达式、控制语句、数组和字符串等等知识点。想要知道更多关于java基础知识的朋友,请阅读本专题下面的的有关文章,欢迎大家来php中文网学习。

1560

2023.10.24

字符串介绍
字符串介绍

字符串是一种数据类型,它可以是任何文本,包括字母、数字、符号等。字符串可以由不同的字符组成,例如空格、标点符号、数字等。在编程中,字符串通常用引号括起来,如单引号、双引号或反引号。想了解更多字符串的相关内容,可以阅读本专题下面的文章。

643

2023.11.24

batoto漫画官网入口与网页版访问指南
batoto漫画官网入口与网页版访问指南

本专题系统整理batoto漫画官方网站最新可用入口,涵盖最新官网地址、网页版登录页面及防走失访问方式说明,帮助用户快速找到batoto漫画官方平台,稳定在线阅读各类漫画内容。

127

2026.02.25

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
C# 教程
C# 教程

共94课时 | 10.2万人学习

C 教程
C 教程

共75课时 | 5万人学习

C++教程
C++教程

共115课时 | 19.5万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号