.NET 6.0 使用log4net配置日志记录方法
1.包管理器引入相关包

2.添加Log4net文件夹和log4net.config配置文件(配置文件属性设为始终复制)。

3.替换 log4net.config的内容(3.1与3.2选择一个就好,只是创建日志文件有所区别)
3.1:
<?xml version="1.0" encoding="utf-8"?>
<configuration><log4net><!--根配置--><root><!--控制级别,由低到高: ALL|DEBUG|INFO|WARN|ERROR|FATAL|OFF--><!--OFF:0--><!--FATAL:FATAL--><!--ERROR: ERROR,FATAL--><!--WARN: WARN,ERROR,FATAL--><!--INFO: INFO,WARN,ERROR,FATAL--><!--DEBUG: INFO,WARN,ERROR,FATAL--><!--ALL: DEBUG,INFO,WARN,ERROR,FATAL--><level value="ALL"/><appender-ref ref="ErrorLog" /><appender-ref ref="WarnLog" /><appender-ref ref="InfoLog" /><appender-ref ref="DebugLog" /><appender-ref ref="FATALLog" /></root><!-- 错误 Error.log--><appender name="ErrorLog" type="log4net.Appender.RollingFileAppender"><!--日志文件路径,可以是相对路径或绝对路径--><file value="Logs\Error"/><encoding value="utf-8"/><!--文件名,按日期生成文件夹--><datePattern value="/yyyy-MM-dd/'Error.log'" /><!--追加日志内容到文件--><appendToFile value="true"/><!--防止多线程时不能写Log,官方说线程非安全--><lockingModel type="log4net.Appender.FileAppender+MinimalLock" /><!--创建日志文件的方式,可选值:Date[日期],文件大小[Size],混合[Composite]--><rollingStyle value="Composite"/><!--分割文件时在扩展名之前--><preserveLogFileNameExtension value="true" /><!--日志最大个数,都是最新的,设为"-1"则不限--><!--rollingStyle节点为Size时,只能有value个日志--><!--rollingStyle节点为Composite时,每天有value个日志--><maxSizeRollBackups value="-1"/><!--单个文件大小。单位:KB|MB|GB--><maximumFileSize value="200MB"/><!--写到一个文件,置为true,则当前最新日志文件名永远为file节中的名字--><staticLogFileName value="false"/><!--日志格式--><layout type="log4net.Layout.PatternLayout"><conversionPattern value="%date{HH:mm:ss.fff} [%thread] %-5level %logger - %message%newline"/></layout><!--输出级别是ERROR的日志,--><filter type="log4net.Filter.LevelRangeFilter"><param name="LevelMin" value="ERROR" /><param name="LevelMax" value="ERROR" /></filter></appender><!-- 警告 Warn.log--><appender name="WarnLog" type="log4net.Appender.RollingFileAppender"><!--日志文件路径,可以是相对路径或绝对路径--><file value="Logs\Warn"/><encoding value="utf-8"/><!--文件名,按日期生成文件夹--><datePattern value="/yyyy-MM-dd/'Warn.log'" /><!--追加日志内容到文件--><appendToFile value="true"/><!--防止多线程时不能写Log,官方说线程非安全--><lockingModel type="log4net.Appender.FileAppender+MinimalLock" /><!--创建日志文件的方式,可选值:Date[日期],文件大小[Size],混合[Composite]--><rollingStyle value="Composite"/><!--分割文件时在扩展名之前--><preserveLogFileNameExtension value="true" /><!--日志最大个数,都是最新的,设为"-1"则不限--><!--rollingStyle节点为Size时,只能有value个日志--><!--rollingStyle节点为Composite时,每天有value个日志--><maxSizeRollBackups value="-1"/><!--单个文件大小。单位:KB|MB|GB--><maximumFileSize value="200MB"/><!--写到一个文件,置为true,则当前最新日志文件名永远为file节中的名字--><staticLogFileName value="false"/><!--日志格式--><layout type="log4net.Layout.PatternLayout"><conversionPattern value="%date{HH:mm:ss.fff} [%thread] %-5level %logger - %message%newline"/></layout><!--输出级别是Warn的日志,--><filter type="log4net.Filter.LevelRangeFilter"><param name="LevelMin" value="WARN" /><param name="LevelMax" value="WARN" /></filter></appender><!-- 信息 Info.log--><appender name="InfoLog" type="log4net.Appender.RollingFileAppender"><!--日志文件路径,可以是相对路径或绝对路径--><file value="Logs\Info"/><encoding value="utf-8"/><!--文件名,按日期生成文件夹--><datePattern value="/yyyy-MM-dd/'Info.log'" /><!--追加日志内容到文件--><appendToFile value="true"/><!--防止多线程时不能写Log,官方说线程非安全--><lockingModel type="log4net.Appender.FileAppender+MinimalLock" /><!--创建日志文件的方式,可选值:Date[日期],文件大小[Size],混合[Composite]--><rollingStyle value="Composite"/><!--分割文件时在扩展名之前--><preserveLogFileNameExtension value="true" /><!--日志最大个数,都是最新的,设为"-1"则不限--><!--rollingStyle节点为Size时,只能有value个日志--><!--rollingStyle节点为Composite时,每天有value个日志--><maxSizeRollBackups value="-1"/><!--单个文件大小。单位:KB|MB|GB--><maximumFileSize value="200MB"/><!--写到一个文件,置为true,则当前最新日志文件名永远为file节中的名字--><staticLogFileName value="false"/><!--日志格式--><layout type="log4net.Layout.PatternLayout"><conversionPattern value="%date{HH:mm:ss.fff} [%thread] %-5level %logger - %message%newline"/></layout><!--输出级别是INFO的日志,--><filter type="log4net.Filter.LevelRangeFilter"><param name="LevelMin" value="INFO" /><param name="LevelMax" value="INFO" /></filter></appender><!-- 调试 Debug.log--><appender name="DebugLog" type="log4net.Appender.RollingFileAppender"><!--日志文件路径,可以是相对路径或绝对路径--><file value="Logs\Debug"/><encoding value="utf-8"/><!--文件名,按日期生成文件夹--><datePattern value="/yyyy-MM-dd/'Debug.log'" /><!--追加日志内容到文件--><appendToFile value="true"/><!--防止多线程时不能写Log,官方说线程非安全--><lockingModel type="log4net.Appender.FileAppender+MinimalLock" /><!--创建日志文件的方式,可选值:Date[日期],文件大小[Size],混合[Composite]--><rollingStyle value="Composite"/><!--分割文件时在扩展名之前--><preserveLogFileNameExtension value="true" /><!--日志最大个数,都是最新的,设为"-1"则不限--><!--rollingStyle节点为Size时,只能有value个日志--><!--rollingStyle节点为Composite时,每天有value个日志--><maxSizeRollBackups value="-1"/><!--单个文件大小。单位:KB|MB|GB--><maximumFileSize value="200MB"/><!--写到一个文件,置为true,则当前最新日志文件名永远为file节中的名字--><staticLogFileName value="false"/><!--日志格式--><layout type="log4net.Layout.PatternLayout"><conversionPattern value="%date{HH:mm:ss.fff} [%thread] %-5level %logger - %message%newline"/></layout><!--输出级别是DEBUG的日志,--><filter type="log4net.Filter.LevelRangeFilter"><param name="LevelMin" value="DEBUG" /><param name="LevelMax" value="DEBUG" /></filter></appender><!-- 严重错误 FATAL.log--><appender name="FATALLog" type="log4net.Appender.RollingFileAppender"><!--日志文件路径,可以是相对路径或绝对路径--><file value="Logs\FATAL"/><encoding value="utf-8"/><!--文件名,按日期生成文件夹--><datePattern value="/yyyy-MM-dd/'FATAL.log'" /><!--追加日志内容到文件--><appendToFile value="true"/><!--防止多线程时不能写Log,官方说线程非安全--><lockingModel type="log4net.Appender.FileAppender+MinimalLock" /><!--创建日志文件的方式,可选值:Date[日期],文件大小[Size],混合[Composite]--><rollingStyle value="Composite"/><!--分割文件时在扩展名之前--><preserveLogFileNameExtension value="true" /><!--日志最大个数,都是最新的,设为"-1"则不限--><!--rollingStyle节点为Size时,只能有value个日志--><!--rollingStyle节点为Composite时,每天有value个日志--><maxSizeRollBackups value="-1"/><!--单个文件大小。单位:KB|MB|GB--><maximumFileSize value="200MB"/><!--写到一个文件,置为true,则当前最新日志文件名永远为file节中的名字--><staticLogFileName value="false"/><!--日志格式--><layout type="log4net.Layout.PatternLayout"><conversionPattern value="%date{HH:mm:ss.fff} [%thread] %-5level %logger - %message%newline"/></layout><!--输出级别是FATAL的日志,--><filter type="log4net.Filter.LevelRangeFilter"><param name="LevelMin" value="FATAL" /><param name="LevelMax" value="FATAL" /></filter></appender><!--SqlServer形式,我这里没这要求,需要的可以使用,在之前根据配置字段和数据集信息创建自己的记录表--><!--Nuget引入程序包:System.Data.Sqlclient--><!--log4net日志配置:http://logging.apache.org/log4net/release/config-examples.html --><appender name="AdoNetAppender_SqlServer" type="log4net.Appender.AdoNetAppender"><!--日志缓存写入条数 设置为0时只要有一条就立刻写到数据库--><bufferSize value="0" /><connectionType value="System.Data.SqlClient.SqlConnection,System.Data.SqlClient, Version=4.6.1.3, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a" /><connectionString value="Data Source=.;Initial Catalog=LogManager;Persist Security Info=True;User ID=sa;Password=123456" /><commandText value="INSERT INTO Log4Net ([Date],[Thread],[Level],[Logger],[Message],[Exception]) VALUES (@log_date, @thread, @log_level, @logger, @message, @exception)" /><parameter><parameterName value="@log_date" /><dbType value="DateTime" /><layout type="log4net.Layout.RawTimeStampLayout" /></parameter><parameter><parameterName value="@thread" /><dbType value="String" /><size value="255" /><layout type="log4net.Layout.PatternLayout"><conversionPattern value="%thread" /></layout></parameter><parameter><parameterName value="@log_level" /><dbType value="String" /><size value="50" /><layout type="log4net.Layout.PatternLayout"><conversionPattern value="%level" /></layout></parameter><parameter><parameterName value="@logger" /><dbType value="String" /><size value="255" /><layout type="log4net.Layout.PatternLayout"><conversionPattern value="%logger" /></layout></parameter><parameter><parameterName value="@message" /><dbType value="String" /><size value="4000" /><layout type="log4net.Layout.PatternLayout"><conversionPattern value="%message" /></layout></parameter><parameter><parameterName value="@exception" /><dbType value="String" /><size value="2000" /><layout type="log4net.Layout.ExceptionLayout" /></parameter></appender></log4net>
</configuration>
创建目录根目录(Logs/下):

3.2
<?xml version="1.0" encoding="utf-8"?>
<configuration><log4net><!-- Define some output appenders --><appender name="rollingAppender" type="log4net.Appender.RollingFileAppender"><!--日志文件路径--><file value="Logs\" /><encoding value="utf-8"/><!--文件名,按日期生成文件夹--><datePattern value="/yyyy-MM-dd/'filename.log'" /><!--追加日志内容--><appendToFile value="true" /><!--防止多线程时不能写Log,官方说线程非安全--><lockingModel type="log4net.Appender.FileAppender+MinimalLock" /><!--可以为:Once|Size|Date|Composite--><!--Composite为Size和Date的组合--><rollingStyle value="Composite" /><!--分割文件时在扩展名之前--><preserveLogFileNameExtension value="true" /><!--当备份文件时,为文件名加的后缀--><!--<datePattern value="yyyyMMdd.TXT" />--><!--日志最大个数,都是最新的--><!--rollingStyle节点为Size时,只能有value个日志--><!--rollingStyle节点为Composite时,每天有value个日志--><maxSizeRollBackups value="10" /><!--可用的单位:KB|MB|GB--><maximumFileSize value="5MB" /><!--置为true,当前最新日志文件名永远为file节中的名字--><staticLogFileName value="false" /><!--输出级别在INFO和ERROR之间的日志--><filter type="log4net.Filter.LevelRangeFilter"><param name="LevelMin" value="INFO" /><param name="LevelMax" value="FATAL" /></filter><layout type="log4net.Layout.PatternLayout"><conversionPattern value="%date{HH:mm:ss.fff} [%thread] %-5level %logger - %message%newline"/></layout><!--<layout type="log4net.Layout.PatternLayout"><conversionPattern value="[%d{HH:mm:ss}]%m%n"/></layout>--></appender><root><priority value="ALL"/><level value="ALL"/><appender-ref ref="rollingAppender" /></root></log4net>
</configuration>
创建目录根目录(Logs/下):

3.3:对配置信息不熟悉的可以参考:【C#】.net core 6.0 使用第三方日志插件Log4net,配置文件详细说明_log4net 日志文件路径-CSDN博客
4.Program下注入(两种方式,哪个有效用哪个):
#region 将Log4Net加入Logging程序集
//方式1:注入Log4Net
//AddLog4Net函数中的参数是配置文件的路径
//如果这个文件创建在根目录下则不用输入参数
//builder.Logging.AddLog4Net("Log4net/log4net2.config");//方式2:注入Log4Net
builder.Services.AddLogging(cfg =>
{cfg.ClearProviders();//删除所有其他的关于日志记录的配置cfg.SetMinimumLevel(LogLevel.Trace);//设置最低的log级别//默认的配置文件路径是在根目录,且文件名为log4net.config//cfg.AddLog4Net();//如果文件路径或名称有变化,需要重新设置其路径或名称//比如在项目根目录下创建一个名为Log4net的文件夹,将log4net.config文件移入其中//则配置如下:cfg.AddLog4Net(new Log4NetProviderOptions(){Log4NetConfigFileName = "Log4net/log4net.config",Watch = true});
});
#endregion
5.使用方式:
[ApiController][Route("[controller]")]public class WeatherForecastController : ControllerBase{private static readonly string[] Summaries = new[]{"Freezing", "Bracing", "Chilly", "Cool", "Mild", "Warm", "Balmy", "Hot", "Sweltering", "Scorching"};//方式1依赖注入private readonly ILogger<WeatherForecastController> _logger;//方式二直接载入private static ILog _log = log4net.LogManager.GetLogger(typeof(WeatherForecastController));public WeatherForecastController(ILogger<WeatherForecastController> logger){_logger = logger;}[HttpGet(Name = "GetWeatherForecast")]public IEnumerable<WeatherForecast> Get(){_logger.LogInformation("11");_logger.LogWarning( "22");_logger.LogDebug( "33");_logger.LogError( "444");_log.Info("AA");_log.Warn("BB");_log.Debug("CC");_log.Error("DD");return Enumerable.Range(1, 5).Select(index => new WeatherForecast{Date = DateTime.Now.AddDays(index),TemperatureC = Random.Shared.Next(-20, 55),Summary = Summaries[Random.Shared.Next(Summaries.Length)]}).ToArray();}}
6.两种使用方式的区别(ILogger是.NET框架提供的一个接口,用于统一不同日志库的调用方式。它本身并不提供具体的日志记录功能,而是通过实现它的类来执行这些操作。):
log4net的ILog接口和依赖注入的ILogger接口主要区别在于它们的实现方式、使用场景和灵活性。
-
实现方式:log4net的ILog接口是log4net库中的一个接口,用于日志记录。它通常是通过直接引入log4net.dll并在代码中手动创建和使用Logger对象来实现的。这种方式下,Logger对象的创建和使用都集中在应用程序代码中。
-
使用场景:log4net的ILog接口更适合于传统的.NET应用程序,其中日志记录是应用程序的一部分,需要通过log4net提供的API来手动控制日志的输出。
-
灵活性:由于log4net的ILog接口是直接集成在应用程序中的,因此它的配置和使用相对固定,不太容易进行灵活的配置更改。例如,如果需要更改日志的输出目标(如文件、数据库等),可能需要修改应用程序代码。
相比之下,依赖注入的ILogger接口是.NET Core及以后版本推荐使用的日志记录方式,它提供了更高的灵活性和扩展性:
-
实现方式:ILogger是通过依赖注入的方式实现的,它是一个接口,可以通过不同的实现类来提供不同的日志记录功能。例如,可以使用Serilog、NLog等第三方库来实现ILogger接口的具体类,从而满足不同的日志记录需求。
-
使用场景:ILogger更适合于现代的应用程序开发,特别是那些需要高度可配置和可扩展的日志记录系统。通过依赖注入,ILogger可以很容易地集成到应用程序中,并且可以通过配置文件或代码进行灵活的配置更改。
-
灵活性:由于ILogger是一个接口,可以通过依赖注入来替换具体的实现类,这使得日志记录系统的更换和升级变得非常容易。此外,由于ILogger接口定义了一组标准的日志记录方法,包括信息、警告、错误等不同级别的日志记录,这为应用程序的开发提供了便利,同时也为日志的分析和处理提供了标准化的数据格式。
总的来说,log4net的ILog接口更适合于传统的.NET应用程序开发,而依赖注入的ILogger接口则更适合于现代应用程序开发,特别是那些需要高度可配置和可扩展的日志记录系统
END..........
相关文章:
.NET 6.0 使用log4net配置日志记录方法
1.包管理器引入相关包 2.添加Log4net文件夹和log4net.config配置文件(配置文件属性设为始终复制)。 3.替换 log4net.config的内容(3.1与3.2选择一个就好,只是创建日志文件有所区别) 3.1: <?xml version"1.0" encoding"utf-8"?> <configuration…...
Unity角色控制及Animator动画切换如走跑跳攻击
Unity角色控制及 Animator动画切换如走跑跳攻击 目录 Unity角色控制及 一、 概念 1、角色控制 1) CharacterController(角色控制器) 2) CapsuleCollider + Rigidbody(使用物理刚体控制) 2、角色动画-Animation、Animator 1) 旧版动画系统...
JSP+Servlet+Mybatis实现列表显示和批量删除等功能
前言 使用JSP回显用户列表,可以进行批量删除(有删除确认步骤),和修改用户数据(用户数据回显步骤)使用servlet处理传递进来的请求参数,并调用dao处理数据并返回使用mybatis,书写dao层…...
Cannot read properties of undefined (reading ‘upgrade‘)
前端开发工具:VSCODE 报错信息: INFO Starting development server...10% building 2/2 modules 0 active ERROR TypeError: Cannot read properties of undefined (reading upgrade)TypeError: Cannot read properties of undefined (reading upgrade…...
javaJUC基础
JUC基础知识 多线程 管程 Monitor,也就是平时所说的锁。Monitor其实是一种同步机制,它的义务是保证(同一时间)只有一个线程可以访问被保护的数据和代码块,JVM中同步是基于进入和退出监视器(Monitor管程对…...
std::distance 函数介绍
std::distance 是 C 标准库中的一个函数模板,用于计算两个迭代器之间的距离。它的主要作用是返回从第一个迭代器到第二个迭代器之间的元素数量。这个函数对于不同类型的迭代器(如随机访问、双向、前向等)都能有效工作。 函数原型 template …...
如何在Windows和Linux之间实现粘贴复制
第一步 sudo apt-get autorremove open-vm-tools第二步 sudo apt-get update第三步 sudo apt-get install open-vm-tools-desktop第四步 一直按Y,希望执行 Y第四步 重启 reboot然后可以实现粘贴复制。...
【第十七章:Sentosa_DSML社区版-机器学习之异常检测】
【第十七章:Sentosa_DSML社区版-机器学习之异常检测】 机器学习异常检测是检测数据集中的异常数据的算子,一种高效的异常检测算法。它和随机森林类似,但每次选择划分属性和划分点(值)时都是随机的,而不是根…...
【Vue】为什么 Vue 不使用 React 的分片更新?
第一,首先时间分片是为了解决 CPU 进行大量计算的问题,因为 React 本身架构的问题,在默认的情况下更新会进行很多的计算,就算使用 React 提供的性能优化 API,进行设置,也会因为开发者本身的问题,…...
大学生科技竞赛系统小程序的设计
管理员账户功能包括:系统首页,个人中心,用户管理,主办方管理,公告栏管理,竞赛分类管理,竞赛信息管理,报名信息管理,竞赛成绩管理 微信端账号功能包括:系统首…...
什么是聚集索引?
什么是聚集索引? 1、聚集索引的特点2、如何确定聚集索引3、性能优势 💖The Begin💖点点关注,收藏不迷路💖 聚集索引是一种特殊的索引,它直接包含了表中的所有数据行。所以,通过聚集索引…...
Centos/fedora/openEuler 终端中文显示配置
注意:这里主要解决的是图形界面、远程登录界面的中文乱码问题 系统原生的终端(如虚拟机系统显示的终端),由于使用的是十分原始的 TTY 终端,使用点阵字体进行显示,点阵字体不支持中文,因此无法显…...
使用kaggle命令下载数据集和模型
点击用户头像,点击Settings: 找到API,点击create new token,将自动下载kaggle.json: 在用户目录下创建.kaggle文件夹,并将下载的kaggle.json文件移动到该文件夹: cd ~ mv Downloads/kaggle.j…...
生信初学者教程(十一):数据校正
介绍 批次效应在生物学数据分析中是一个普遍存在的问题,它指的是由于实验过程中非生物学因素(如样本处理时间、实验条件、测序平台等)的差异,导致实验结果中混入与研究目标不相关的变异。在比较对照组和实验组时,这些非生物学因素可能引入额外的噪声,影响对生物学问题真实…...
JS设计模式之桥接模式:搭建跨越维度的通路
引言 在软件开发中,我们经常遇到需要对不同的抽象类进行不同的实现的情况,而传统的对象嵌套并不是一个优雅且可扩展的解决方案,因此这正是桥接模式的用武之地。桥接模式通过将抽象与实现分离,使得它们可以独立变化,从…...
苹果电脑系统重磅更新——macOS Sequoia 15 系统 新功能一 览
有了 macoS Sequoia,你的工作效率将再次提升:快速调整桌面布局,一目了然地浏览网页重点,还可以通过无线镜像功能操控你的iPhone。 下面就来看看几项出色新功能,还有能够全面发挥这些功能的 App 和游戏。 macOS Sequo…...
DoppelGanger++:面向数据库重放的快速依赖关系图生成
doi:DoppelGanger: Towards Fast Dependency Graph Generation for Database Replay,点击前往 文章目录 1 简介2 架构概述3 依赖关系图3.1 符号和问题定义3.2 无 IT(k) 图3.3 无 OT 图表3.4 无 OTIT 图表3.5 无 IT[OT] 图表3.6 输出确定性保证 4 重复向后…...
Linux(含麒麟操作系统)如何实现多显示器屏幕采集录制
技术背景 在操作系统领域,很多核心技术掌握在国外企业手中。如果过度依赖国外技术,在国际形势变化、贸易摩擦等情况下,可能面临技术封锁和断供风险。开发国产操作系统可以降低这种风险,确保国家关键信息基础设施的稳定运行。在一…...
calibre-web默认左上角字体修改
calibre-web默认左上角字体修改 如图: 有些奇异,如果想变成正常的常规字体,需要修改: cps\static\css\style.css 下的代码: 默认是GrandHotel-Regular: 换成其他字体即可。其他字体在 calibre-web\cps\s…...
考研数据结构——C语言实现归并排序
包含头文件:程序首先包含了标准输入输出库stdio.h,以便使用printf等函数进行输入输出操作。 定义数组和数组大小:定义了一个宏N,其值为5,表示数组q的长度。数组q被初始化为{5, 3, 8, 4, 2},这是我们要排序…...
C/C++ 中附加包含目录、附加库目录与附加依赖项详解
在 C/C 编程的编译和链接过程中,附加包含目录、附加库目录和附加依赖项是三个至关重要的设置,它们相互配合,确保程序能够正确引用外部资源并顺利构建。虽然在学习过程中,这些概念容易让人混淆,但深入理解它们的作用和联…...
三分算法与DeepSeek辅助证明是单峰函数
前置 单峰函数有唯一的最大值,最大值左侧的数值严格单调递增,最大值右侧的数值严格单调递减。 单谷函数有唯一的最小值,最小值左侧的数值严格单调递减,最小值右侧的数值严格单调递增。 三分的本质 三分和二分一样都是通过不断缩…...
MySQL 索引底层结构揭秘:B-Tree 与 B+Tree 的区别与应用
文章目录 一、背景知识:什么是 B-Tree 和 BTree? B-Tree(平衡多路查找树) BTree(B-Tree 的变种) 二、结构对比:一张图看懂 三、为什么 MySQL InnoDB 选择 BTree? 1. 范围查询更快 2…...
深入浅出Diffusion模型:从原理到实践的全方位教程
I. 引言:生成式AI的黎明 – Diffusion模型是什么? 近年来,生成式人工智能(Generative AI)领域取得了爆炸性的进展,模型能够根据简单的文本提示创作出逼真的图像、连贯的文本,乃至更多令人惊叹的…...
Xela矩阵三轴触觉传感器的工作原理解析与应用场景
Xela矩阵三轴触觉传感器通过先进技术模拟人类触觉感知,帮助设备实现精确的力测量与位移监测。其核心功能基于磁性三维力测量与空间位移测量,能够捕捉多维触觉信息。该传感器的设计不仅提升了触觉感知的精度,还为机器人、医疗设备和制造业的智…...
UE5 音效系统
一.音效管理 音乐一般都是WAV,创建一个背景音乐类SoudClass,一个音效类SoundClass。所有的音乐都分为这两个类。再创建一个总音乐类,将上述两个作为它的子类。 接着我们创建一个音乐混合类SoundMix,将上述三个类翻入其中,通过它管理每个音乐…...
数据分析六部曲?
引言 上一章我们说到了数据分析六部曲,何谓六部曲呢? 其实啊,数据分析没那么难,只要掌握了下面这六个步骤,也就是数据分析六部曲,就算你是个啥都不懂的小白,也能慢慢上手做数据分析啦。 第一…...
LangChain【6】之输出解析器:结构化LLM响应的关键工具
文章目录 一 LangChain输出解析器概述1.1 什么是输出解析器?1.2 主要功能与工作原理1.3 常用解析器类型 二 主要输出解析器类型2.1 Pydantic/Json输出解析器2.2 结构化输出解析器2.3 列表解析器2.4 日期解析器2.5 Json输出解析器2.6 xml输出解析器 三 高级使用技巧3…...
【工具教程】多个条形码识别用条码内容对图片重命名,批量PDF条形码识别后用条码内容批量改名,使用教程及注意事项
一、条形码识别改名使用教程 打开软件并选择处理模式:打开软件后,根据要处理的文件类型,选择 “图片识别模式” 或 “PDF 识别模式”。如果是处理包含条形码的 PDF 文件,就选择 “PDF 识别模式”;若是处理图片文件&…...
调试快捷键 pycharm vscode
目录 调试快捷键 pycharm vscode 修改快捷键 方法 1:通过菜单打开 方法 2:用快捷键打开 调试快捷键 pycharm Resume Program F9 Step Over F8 两个离的比较近,比较方便,比vscode的好。 vscode Continue F5 改为F9 S…...
