当前位置: 首页 > news >正文

VB.NET 正则表达式完全指南

VB.NET 正则表达式完全指南

VB.NET通过 System.Text.RegularExpressions 命名空间提供正则表达式支持。本指南将详细介绍VB.NET中正则表达式的使用方法、性能优化和最佳实践。

1. 基础知识

1.1 导入命名空间

Imports System.Text.RegularExpressions

1.2 基本使用

Public Class RegexBasicsPublic Sub BasicExamples()Dim text As String = "Hello, my phone is 123-456-7890"' 创建正则表达式对象Dim regex As New Regex("\d+")' 检查是否匹配Dim isMatch As Boolean = regex.IsMatch(text)' 查找第一个匹配Dim match As Match = regex.Match(text)If match.Success ThenConsole.WriteLine($"Found: {match.Value}")End If' 查找所有匹配Dim matches As MatchCollection = regex.Matches(text)For Each m As Match In matchesConsole.WriteLine($"Found: {m.Value}")NextEnd Sub
End Class

1.3 正则表达式选项

Public Class RegexOptionsPublic Sub OptionsExample()' 不区分大小写Dim caseInsensitive As New Regex("hello", RegexOptions.IgnoreCase)' 多行模式Dim multiline As New Regex("^start", RegexOptions.Multiline)' 忽略空白字符和注释Dim ignored As New Regex("\d+  # 匹配数字\s*  # 可选的空白字符\w+  # 匹配单词", RegexOptions.IgnorePatternWhitespace)' 编译正则表达式以提高性能Dim compiled As New Regex("\d+", RegexOptions.Compiled)End Sub
End Class

2. 正则表达式语法

2.1 字符匹配

Public Class CharacterMatchingPublic Sub MatchingExamples()Dim text As String = "VB.NET 2022 is awesome! Price: $99.99"' 匹配数字Dim digits As New Regex("\d+")For Each m As Match In digits.Matches(text)Console.WriteLine($"Number: {m.Value}")Next' 匹配单词Dim words As New Regex("\w+")Dim wordMatches = words.Matches(text).Cast(Of Match)().Select(Function(m) m.Value).ToList()' 匹配空白字符Dim parts() As String = Regex.Split(text, "\s+")' 自定义字符类Dim vowels As New Regex("[aeiou]", RegexOptions.IgnoreCase)Dim vowelMatches = vowels.Matches(text).Cast(Of Match)().Select(Function(m) m.Value).ToList()End Sub
End Class

2.2 分组和捕获

Public Class GroupingExamplePublic Sub GroupExamples()Dim text As String = "John Smith, Jane Doe, Bob Johnson"' 基本分组Dim regex As New Regex("(\w+)\s(\w+)")For Each match As Match In regex.Matches(text)Console.WriteLine($"Full name: {match.Groups(0).Value}")Console.WriteLine($"First name: {match.Groups(1).Value}")Console.WriteLine($"Last name: {match.Groups(2).Value}")Next' 命名分组Dim namedRegex As New Regex("(?<first>\w+)\s(?<last>\w+)")For Each match As Match In namedRegex.Matches(text)Console.WriteLine($"First: {match.Groups("first").Value}")Console.WriteLine($"Last: {match.Groups("last").Value}")NextEnd Sub
End Class

3. 高级特性

3.1 替换操作

Public Class ReplacementOperationsPublic Function ReplaceExample(text As String) As String' 简单替换Dim result1 As String = Regex.Replace(text, "\d+", "X")' 使用委托Dim result2 As String = Regex.Replace(text, "\d+", _Function(match As Match)Dim number As Integer = Integer.Parse(match.Value)Return (number * 2).ToString()End Function)' 使用命名组的替换Dim regex As New Regex("(?<first>\w+)\s(?<last>\w+)")Dim result3 As String = regex.Replace(text, "${last}, ${first}")Return result3End Function
End Class

3.2 前瞻和后顾

Public Class LookAroundExamplePublic Sub LookAroundDemo()Dim text As String = "Price: $100, Cost: $50"' 正向前瞻Dim positiveAhead As New Regex("\d+(?=\s*dollars)")' 负向前瞻Dim negativeAhead As New Regex("\d+(?!\s*dollars)")' 正向后顾Dim positiveBehind As New Regex("(?<=\$)\d+")' 负向后顾Dim negativeBehind As New Regex("(?<!\$)\d+")End Sub
End Class

4. 实用工具类

4.1 验证器

Public Class ValidatorPrivate Shared ReadOnly EmailRegex As New Regex("^[a-zA-Z0-9._%+-]+@[a-zA-Z0-9.-]+\.[a-zA-Z]{2,}$",RegexOptions.Compiled)Private Shared ReadOnly PhoneRegex As New Regex("^1[3-9]\d{9}$",RegexOptions.Compiled)Private Shared ReadOnly PasswordRegex As New Regex("^(?=.*[A-Za-z])(?=.*\d)[A-Za-z\d]{8,}$",RegexOptions.Compiled)Public Shared Function IsValidEmail(email As String) As BooleanIf String.IsNullOrEmpty(email) Then Return FalseReturn EmailRegex.IsMatch(email)End FunctionPublic Shared Function IsValidPhone(phone As String) As BooleanIf String.IsNullOrEmpty(phone) Then Return FalseReturn PhoneRegex.IsMatch(phone)End FunctionPublic Shared Function IsValidPassword(password As String) As BooleanIf String.IsNullOrEmpty(password) Then Return FalseReturn PasswordRegex.IsMatch(password)End Function
End Class

4.2 文本处理器

Public Class TextProcessorPrivate Shared ReadOnly UrlRegex As New Regex("https?://(?:[-\w.]|(?:%[\da-fA-F]{2}))+[^\s]*",RegexOptions.Compiled)Private Shared ReadOnly HtmlTagRegex As New Regex("<[^>]+>",RegexOptions.Compiled)Public Shared Function ExtractUrls(text As String) As IEnumerable(Of String)If String.IsNullOrEmpty(text) Then Return Enumerable.Empty(Of String)Return UrlRegex.Matches(text).Cast(Of Match)().Select(Function(m) m.Value)End FunctionPublic Shared Function StripHtmlTags(html As String) As StringIf String.IsNullOrEmpty(html) Then Return String.EmptyReturn HtmlTagRegex.Replace(html, String.Empty)End FunctionPublic Shared Function CleanWhitespace(text As String) As StringIf String.IsNullOrEmpty(text) Then Return String.EmptyReturn Regex.Replace(text.Trim(), "\s+", " ")End Function
End Class

5. 性能优化

5.1 静态编译正则表达式

Public Class RegexOptimization' 使用共享字段存储编译后的正则表达式Private Shared ReadOnly CompiledRegex As New Regex("\d+",RegexOptions.Compiled)' 使用延迟初始化Private Shared ReadOnly LazyRegex As New Lazy(Of Regex)(Function() New Regex("\d+", RegexOptions.Compiled))Public Sub OptimizedExample()' 使用编译后的正则表达式Dim isMatch As Boolean = CompiledRegex.IsMatch("123")' 使用延迟初始化的正则表达式Dim lazyMatch As Boolean = LazyRegex.Value.IsMatch("123")End Sub
End Class

5.2 性能考虑

Public Class PerformanceConsiderations' 1. 使用适当的选项Private Shared ReadOnly FastRegex As New Regex("\d+",RegexOptions.Compiled Or RegexOptions.ExplicitCapture)' 2. 避免过度使用通配符Private Shared ReadOnly BetterRegex As New Regex("[^/]*foo[^/]*",  ' 比 .*foo.* 更高效RegexOptions.Compiled)' 3. 使用非捕获组Private Shared ReadOnly NonCapturingRegex As New Regex("(?:\d+)(?:[a-z]+)",  ' 使用(?:)表示非捕获组RegexOptions.Compiled)
End Class

6. 异常处理

Public Class RegexExceptionHandlingPublic Shared Function CreateSafeRegex(pattern As String) As RegexTryReturn New Regex(pattern, RegexOptions.Compiled)Catch ex As ArgumentExceptionThrow New ArgumentException($"Invalid regex pattern: {ex.Message}", ex)End TryEnd FunctionPublic Shared Function SafeIsMatch(input As String, pattern As String) As BooleanTryReturn Regex.IsMatch(input, pattern)Catch ex As RegexMatchTimeoutExceptionConsole.WriteLine($"Regex matching timed out: {ex.Message}")Return FalseCatch ex As ArgumentExceptionConsole.WriteLine($"Invalid regex pattern: {ex.Message}")Return FalseEnd TryEnd Function
End Class

7. 单元测试

<TestClass>
Public Class ValidatorTests<TestMethod>Public Sub TestEmailValidation()Assert.IsTrue(Validator.IsValidEmail("test@example.com"))Assert.IsTrue(Validator.IsValidEmail("user@domain.co.uk"))Assert.IsFalse(Validator.IsValidEmail("invalid.email"))Assert.IsFalse(Validator.IsValidEmail("@domain.com"))End Sub<TestMethod>Public Sub TestPhoneValidation()Assert.IsTrue(Validator.IsValidPhone("13812345678"))Assert.IsFalse(Validator.IsValidPhone("12345678"))Assert.IsFalse(Validator.IsValidPhone("2381234567"))End Sub<TestMethod>Public Sub TestTextProcessing()Dim html As String = "<p>Hello</p><div>World</div>"Assert.AreEqual("HelloWorld",TextProcessor.StripHtmlTags(html))Dim text As String = "  multiple   spaces   here  "Assert.AreEqual("multiple spaces here",TextProcessor.CleanWhitespace(text))End Sub
End Class

总结

VB.NET的正则表达式实现具有以下特点:

  1. 完整的.NET正则表达式引擎支持
  2. 编译选项提供高性能
  3. LINQ集成
  4. 完整的Unicode支持

最佳实践:

  1. 使用共享(Shared)编译的Regex对象提高性能
  2. 合理使用RegexOptions
  3. 处理超时和异常情况
  4. 编写完整的单元测试
  5. 使用命名捕获组提高可读性

注意事项:

  1. Regex对象创建开销大,应该重用
  2. 考虑使用Compiled选项提高性能
  3. 处理RegexMatchTimeoutException
  4. 注意内存使用

记住:在VB.NET中使用正则表达式时,要充分利用.NET框架提供的功能。VB.NET的语法可能与C#略有不同,但底层的正则表达式引擎是相同的。合理使用静态编译和缓存可以显著提高性能。

相关文章:

VB.NET 正则表达式完全指南

VB.NET 正则表达式完全指南 VB.NET通过 System.Text.RegularExpressions 命名空间提供正则表达式支持。本指南将详细介绍VB.NET中正则表达式的使用方法、性能优化和最佳实践。 1. 基础知识 1.1 导入命名空间 Imports System.Text.RegularExpressions1.2 基本使用 Public C…...

ASP.NET Core - 配置系统之自定义配置提供程序

ASP.NET Core - 配置系统之自定义配置提供程序 4. 自定义配置提供程序IConfigurationSourceIConfigurationProvider 4. 自定义配置提供程序 在 .NET Core 配置系统中封装一个配置提供程序关键在于提供相应的 IconfigurationSource 实现和 IConfigurationProvider 接口实现&…...

大语言模型的稀疏性:提升效率与性能的新方向

大语言模型的稀疏性&#xff1a;提升效率与性能的新方向 大语言模型&#xff08;LLM, Large Language Model&#xff09;随着参数规模的不断扩大&#xff0c;其性能得到了显著提升&#xff0c;但也带来了巨大的计算和存储开销。稀疏性&#xff08;Sparsity&#xff09;作为一种…...

迅为RK3568开发板篇OpenHarmony配置HDF驱动控制LED-新增 topeet子系统-编写 bundle.json文件

bundle.json 文件内容如下所示&#xff1a; 下面是对各个字段的解释&#xff1a; 1. name: "ohos/demos" - 这是组件或项目的名称&#xff0c;这里表示它属于 OHOS&#xff08;OpenHarmony OS&#xff09;生态系统下的一个名为"demos"的组件。 2. descri…...

vulnhub靶场【IA系列】之Tornado

前言 靶机&#xff1a;IA-Tornado&#xff0c;IP地址为192.168.10.11 攻击&#xff1a;kali&#xff0c;IP地址为192.168.10.2 都采用虚拟机&#xff0c;网卡为桥接模式 本文所用靶场、kali镜像以及相关工具&#xff0c;我放置在网盘中&#xff0c;可以复制后面链接查看 htt…...

GB44495-2024 汽车整车信息安全技术要求 - V2X部分前置要求

背景 GB 44495-2024《汽车整车信息安全技术要求》中关于V2X&#xff08;车与外界通信&#xff09;的部分&#xff0c;主要关注于通信安全要求&#xff0c;旨在确保车辆在与外部设备进行数据交互时的信息安全。其测试大致可分为消息层&#xff08;数据无异常&#xff09;、应用…...

基于mediapipe的手势游戏控制

基于mediapipe的手势游戏控制 ​ 玩游戏&#xff0c;那不是有手就行!!! mediapipe介绍 ​ Mediapipe是Google在2019年开发并提出的一款开源的跨平台多媒体处理框架&#xff0c;用于构建基于机器学习的应用程序&#xff0c;特别是涉及到计算机视觉、音频处理、姿势估计等领域。…...

K8S 节点选择器

今天我们来实验 pod 调度的 nodeName 与 nodeSelector。官网描述如下&#xff1a; 假设有如下三个节点的 K8S 集群&#xff1a; k8s31master 是控制节点 k8s31node1、k8s31node2 是工作节点 容器运行时是 containerd 一、镜像准备 1.1、镜像拉取 docker pull tomcat:8.5-jre8…...

IEC103 转 ModbusTCP 网关

一、产品概述 IEC103 转 ModbusTCP 网关型号 SG-TCP-IEC103 &#xff0c;是三格电子推出的工业级网关&#xff08;以下简 称网关&#xff09;&#xff0c;主要用于 IEC103 数据采集、 DLT645-1997/2007 数据采集&#xff0c; IEC103 支持遥测和遥 信&#xff0c;可接…...

docker swarm 部署问题 和 指定节点部署服务

问题原因&#xff1a; docker swarm 部署遇到的问题&#xff0c; 先前docker compose部署&#xff0c;分别创建了 cloud 网络&#xff1b; 昨进行swarm 集群部署&#xff1b;只是删了57 机器cloud 网络&#xff1b;在创建swarm集群后创建cloud 58机器 没有删除先前的cloud 网络…...

09.VSCODE:安装 Git for Windows

在 Windows 下安装著名的源代码管理工具&#xff1a;git。 git 工具两大作用&#xff1a; 管理我们自己的源代码获取他人&#xff08;开源的&#xff09;源代码 当前我们更需要第2点。 为什么要安装 git 一、 得到更多库 之前课程中我们安装了 msys2&#xff0c;从而可以通…...

基于R计算皮尔逊相关系数

# 基于R计算皮尔逊相关系数 # 函数 基本基本函数 cor.test ## 两组数据读入 xread.csv("1.csv",header T) yread.csv("2.csv",header T) ## 计算 cor.test(1,2,method"pearson") 结果 Pearsons product-moment correlationdata: 1 and 2…...

vue 纯前端导出 Excel

方法一&#xff1a; 1、安装"file-saver" npm i -S file-saver xlsx 2、引入 在需要导出功能的 .vue 文件中引入 import FileSaver from "file-saver"; import XLSX from "xlsx"; 3、简单示例&#xff08;复制即可食用&#xff09;&#x…...

APISQL在线一键安装教程

本文档将指导您在 Linux 服务器上使用 Docker 安装 APISQL 软件。提供了两种安装方式&#xff1a;在线安装和离线安装&#xff0c;您可以根据实际环境选择合适的安装方式。 1. 准备工作 1.1 硬件要求 Linux (x86_64) 服务器 1.2 软件要求 Docker Engine 推荐版本&#xff…...

数据结构《MapSet哈希表》

文章目录 一、搜索树1.1 定义1.2 模拟实现搜索 二、Map2.1 定义2.2 Map.Entry2.3 TreeMap的使用2.4 Map的常用方法 三、Set3.1 定义3.2 TreeSet的使用3.3 Set的常用方法 四、哈希表4.1 哈希表的概念4.2 冲突4.2.1 冲突的概念4.2.2 冲突的避免1. 选择合适的哈希函数2. 负载因子调…...

【PCL】sample_consensus 模块—— Random Sample Consensus model(随机样本一致性模型,RANSAC)

1、随机样本一致性模型&#xff08;RANSAC&#xff09;简介 在本教程中&#xff0c;我们将学习如何使用带有平面模型的随机样本一致性&#xff08;RANSAC&#xff09;来获取适合该模型的点云。 1.1理论背景 RANSAC 是“随机样本一致性”&#xff08;RANdom SAmple Consensus…...

【MATLAB代码】CV和CA模型组成的IMM(滤波方式为UKF),可复制粘贴源代码

该代码实现了一维无迹卡尔曼滤波器(UKF)与交互式多模型(IMM)结合的状态估计。代码分为多个部分,主要功能包括参数定义、观测数据生成、状态估计、模型更新以及结果可视化。 文章目录 运行结果程序代码主要功能代码结构应用场景注意事项运行结果 程序代码 下方源代码直接粘…...

docker-compose部署kafka 3.3.1 kraft

一、服务器&#xff1a; 节点1:10.1.1.165 节点2:10.1.1.164 节点3:10.1.1.169二、添加环境地址解析 vim /etc/hosts kafka1 10.1.1.165 kafka2 10.1.1.164 kafka3 10.1.1.169三、节点配置 节点1 version: "3" services:kafka1:image: bitnami/kafka:3.3.1contain…...

Linux 串口检查状态的实用方法

在 Linux 系统中&#xff0c;串口通信是非常常见的操作&#xff0c;尤其在嵌入式系统、工业设备以及其他需要串行通信的场景中。为了确保串口设备的正常工作&#xff0c;检查串口的连接状态和配置信息是非常重要的。本篇文章将介绍如何在 Linux 上检查串口的连接状态&#xff0…...

使用FRP进行内网穿透

一、基本概念 内网穿透&#xff1a;它是一种网络技术或方法&#xff0c;旨在允许外部网络&#xff08;如互联网&#xff09;访问位于内部网络&#xff08;内网&#xff09;中的设备或服务。由于内部网络通常处于NAT&#xff08;网络地址转换&#xff09;、防火墙或其他安全机制…...

Ubuntu打开文件夹不显示文件

1.情况介绍 使用ubuntu打开文件夹不显示文件夹里面的内容&#xff0c;而是直接打开了资源查看器。 2.解决办法 命令行安装nautilus sudo apt-get install nautilus...

HarmonyOS NEXT应用开发边学边玩系列:从零实现一影视APP (三、影视搜索页功能实现)

在HarmonyOS NEXT开发环境中&#xff0c;可以使用nutpi/axios库来简化网络请求的操作。本文将展示如何使用HarmonyOS NEXT框架和nutpi/axios库&#xff0c;从零开始实现一个简单的影视APP&#xff0c;主要关注影视搜索页的功能实现。 为什么选择nutpi/axios&#xff1f; nutpi…...

探秘 JMeter 前置处理器:让性能测试如虎添翼

想象一下&#xff0c;你是一位超级英雄&#xff0c;要对一个庞大的虚拟城市&#xff08;Web 应用&#xff09;进行全面的 “健康检查”。JMeter 就是你的神奇工具包&#xff0c;而其中的前置处理器&#xff0c;就像是这个工具包里的各种超级武器&#xff0c;能帮助你轻松应对各…...

如何在gitlab cicd中实现每月10号上午执行

在 GitLab CI/CD 中&#xff0c;可以通过设置定时触发器&#xff08;Schedules&#xff09;和脚本中的时间判断逻辑结合&#xff0c;确保任务只在每月 10 号的上午运行。 以下是实现的步骤&#xff1a; 1. 设置定时触发器 GitLab 提供了 Schedules 功能&#xff0c;可以指定每…...

深度学习基础知识

深度学习是人工智能&#xff08;AI&#xff09;和机器学习&#xff08;ML&#xff09;领域的一个重要分支&#xff0c;以下是对深度学习基础知识的归纳&#xff1a; 一、定义与原理 定义&#xff1a;深度学习是一种使计算机能够从经验中学习并以概念层次结构的方式理解世界的机…...

面试加分项:Android Framework AMS 全面概述和知识要点

第一章:AMS 的架构与组件 1.1 AMS 整体架构 在 Android 系统的庞大体系中,AMS(Activity Manager Service)就如同一个中枢神经系统,是整个系统的核心服务之一,对应用的性能和用户体验有着直接且关键的影响 。它的整体架构由 Client 端和 Service 端两大部分组成,这两端相…...

网安——CSS

一、CSS基础概念 CSS有两个重要的概念&#xff0c;分为样式和布局 CSS的样式分为两种&#xff0c;一种是文字的样式&#xff0c;一种是盒模型的样式 CSS的另一个重要的特质就是辅助页面布局&#xff0c;完成HTML不能完成的功能&#xff0c;比如并排显示或精确定位显示 从HT…...

知识图谱常见的主流图数据库

在知识图谱中&#xff0c;主流使用的图数据库包括以下几种&#xff1a; Neo4j&#xff1a;这是目前全球部署最广泛的图数据库之一&#xff0c;具有强大的查询性能和灵活的数据模型&#xff0c;适用于复杂关系数据的存储和查询。 JanusGraph&#xff1a;JanusGraph是一个开源的…...

阀井可燃气体监测仪,开启地下管网安全新篇章-旭华智能

在城市的脉络中&#xff0c;地下管网犹如隐秘的动脉&#xff0c;支撑着现代生活的运转。而在这庞大网络的关键节点上&#xff0c;阀井扮演着不可或缺的角色。然而&#xff0c;由于其密闭性和复杂性&#xff0c;阀井内部一旦发生可燃气体泄漏&#xff0c;将对公共安全构成严重威…...

【6】Word:海名公司文秘❗

目录 题目 List.docx Word.docx List.docx和Word.docx 题目 List.docx 选中1/4全角空格复制→选中全部文本→开始→替换&#xff1a;粘贴将1/4全角空格 替换成 空格选中全部文本→插入→表格→将文本转化成表格→勾选和布局→自动调整→勾选 选中第一列&#xff0c;单机右键…...

微信原生小程序自定义封装组件(以导航navbar为例)

封装 topnav.js const App getApp(); Component({// 组件的属性列表properties: {pageName: String, //中间的titleshowNav: { //判断是否显示左上角的按钮 type: Boolean,value: true},showHome: { //判断是否显示左上角的home按钮type: Boolean,value: true},showLocat…...

<OS 有关>Ubuntu 24 安装 openssh-server, tailscale+ssh 慢增加

更新日志&#xff1a; Created on 14Jan.2025 by Dave , added openssh-server, tailescape Updated on 15Jan.2025, added "tailescape - tailscape ssh" 前期准备&#xff1a; 1. 更新可用软件包的数据库 2. 升级系统中所有已安装的软件包到最新版本 3. 安装 cur…...

HQL(JPQL)和原生SQL实现查询自定义返回类

维修申请实例RepairApplyInstance: package com.byx.scaffold.common.entity.jpa;import com.byx.scaffold.common.entity.jpaEnum.RepairStatusConstant; import lombok.Data;import javax.persistence.Convert; import javax.persistence.Entity; import javax.persistence…...

微信小程序 实现拼图功能

微信小程序 实现拼图 效果示例功能描述代码示例 效果示例 微信小程序 碎片拼图 功能描述 在微信小程序中&#xff0c;实现一个简单的拼图小游戏。用户需要将四张碎片图片拖动到目标图片的正确位置&#xff0c;具体功能如下&#xff1a; 拖动功能&#xff1a; 用户可以通过手指…...

《C++11》并发库:简介与应用

在C11之前&#xff0c;C并没有提供原生的并发支持。开发者通常需要依赖于操作系统的API&#xff08;如Windows的CreateThread或POSIX的pthread_create&#xff09;或者第三方库&#xff08;如Boost.Thread&#xff09;来创建和管理线程。这些方式存在以下几个问题&#xff1a; …...

【RDMA学习笔记】1:RDMA(Remote Direct Memory Access)介绍

从帝国理工的PPT学习。 什么是RDMA Remote Direct Memory Access&#xff0c;也就是Remote的DMA&#xff0c;是一种硬件机制&#xff0c;能直接访问远端结点的内存&#xff0c;而不需要处理器介入。 其中&#xff1a; Remote&#xff1a;跨node进行数据传输Direct&#xff…...

Autodl转发端口,在本地机器上运行Autodl服务器中的ipynb文件

通过 SSH 隧道将远程端口转发到本地机器 输入服务器示例的SSH指令和密码&#xff0c;将远程的6006端口代理到本地 在服务器终端&#xff0c;激活conda虚拟环境 conda activate posecnnexport PYOPENGL_PLATFORMegljupyter notebook --no-browser --port6006 --allow-root从…...

【Linux】常见指令(一)

Linux常见指令 01.whoami02.pwd03.ls04.mkdir05.cd 本文LInux环境为&#xff0c;使用XShell远程登陆到Linux。 具体如何环境搭建&#xff0c;大家可以查看其他博客。 01.whoami whoami 指令用来查看当前账户是谁。 如上图所示&#xff0c;使用whoami指令&#xff0c;查看到现在…...

AI学习之自然语言处理(NLP)

自然语言处理&#xff08;Natural Language Processing&#xff0c;NLP&#xff09;是计算机科学、人工智能和语言学领域的交叉学科&#xff0c;旨在让计算机能够理解、处理和生成人类语言。以下为你详细介绍&#xff1a; 自然语言处理的关键技术 词法分析&#xff1a;将文本…...

全面解析锁服务设计:内存锁、数据库锁与分布式锁的选择与实现

在构建分布式系统时&#xff0c;锁服务通常用于控制多个线程或进程对共享资源的访问。为了灵活适配不同的锁实现方式&#xff0c;我们可以设计一个基础的锁服务接口&#xff0c;然后根据需求提供不同的实现。例如&#xff0c;内存锁、数据库锁和分布式锁。 1. 锁服务基础接口设…...

jenkins-系统配置概述

一. 引文&#xff1a; Jenkins除了强大的功能插件实现的持续交付集成外&#xff0c; 本身也是有一些比较重要的可配项。 接下来我们来看一看。 配置入口: 系统管理-->系统设置 二. 基础配置&#xff1a; 1.主目录(home directory): Jenkins所有的数据文件存放路径(可通过…...

《数据思维》之数据可视化_读书笔记

文章目录 系列文章目录前言一、pandas是什么&#xff1f;二、使用步骤 1.引入库2.读入数据总结 前言 数据之道&#xff0c;路漫漫其修远兮&#xff0c;吾将上下而求索。 一、数据可视化 最基础的数据可视化方法就是统计图。一个好的统计图应该满足四个标准&#xff1a;准确、有…...

kafka消费堆积问题探索

背景 我们的商城项目用PHP写的&#xff0c;原本写日志方案用的是PHP的方案&#xff0c;但是&#xff0c;这个方案导致资源消耗一直降不下来&#xff0c;使用了20个CPU。后面考虑使用通过kafka的方案写日志&#xff0c;商城中把产生的日志丢到kafka中&#xff0c;在以go写的项目…...

一文掌握Docker

目录 1.快速入门 1.1.部署MySQL 1.2.命令解读 2.Docker基础 2.1.常见命令 2.1.1.命令介绍 2.1.2.演示 2.1.3.命令别名 2.2.数据卷 2.2.1.什么是数据卷 2.2.2.数据卷命令 2.2.3.挂载本地目录或文件 2.3.镜像 2.3.1.镜像结构 2.3.2.Dockerfile构建镜像 2.3.3.构建…...

慧集通(DataLinkX)iPaaS集成平台-系统管理之UI库管理、流程模板

UI库管理 UI库管理分为平台级和自建两种&#xff0c;其中平台级就是慧集通平台自己内置的一些ui库所有客户均可调用&#xff0c;自建则是平台支持使用者自己根据规则自己新增对应的UI库。具体界面如下&#xff1a; 自建UI库新增界面&#xff1a; 注&#xff1a;平台级UI库不支…...

【学习笔记】Macbook管理多个不同的Python版本

在MacBook上管理不同项目的不同Python版本&#xff0c;可以使用多种方法。以下是一些常见的方法&#xff1a; 1. 使用 pyenv pyenv 是一个非常流行的工具&#xff0c;可以让你轻松安装和切换多个Python版本。以下是安装和使用 pyenv 的步骤&#xff1a; 安装 pyenv 安装依赖…...

前端如何设计一个回溯用户操作的方案

同一个项目&#xff0c;为什么我本地无法复现&#xff0c;只有客户的设备才复现&#xff1f; 如何获取用户的操作路径呢&#xff1f; 两种方案&#xff1a;埋点和rrweb 埋点就很简单了&#xff0c;将所有可能操作的节点都进行预埋数据&#xff1b;但埋点简单并不省心&#xff…...

WPF、控件模板(ControlTemplate)和数据模板(DataTemplate)

前言 在 WPF 中&#xff0c;控件种类丰富且功能非常完善。一个显著的优点是 WPF 提供了强大的自定义能力和灵活的用户界面表现&#xff0c;能够满足各种复杂的应用需求。其中&#xff0c;ControlTemplate 和 DataTemplate 是两个非常重要的概念&#xff0c;分别用于自定义控件…...

MAC上安装Octave

1. 当前最新版Octave是9.3版本&#xff0c;需要把mac os系统升级到14版本&#xff08;本人之前的版本是10版本&#xff09; https://wiki.octave.org/Octave_for_macOS octave的历史版本参考此文档&#xff1a;Octave for macOS (outdated) - Octavehttps://wiki.octave.org/Oc…...

RabbitMQ(三)

RabbitMQ中的各模式及其用法 工作队列模式一、生产者代码1、封装工具类2、编写代码3、发送消息效果 二、消费者代码1、编写代码2、运行效果 发布订阅模式一、生产者代码二、消费者代码1、消费者1号2、消费者2号 三、运行效果四、小结 路由模式一、生产者代码二、消费者代码1、消…...