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

Ethers.js 开发入门:核心功能、最佳实践与避坑指南

引言

Ethers.js 是当前 Web3 开发领域增长最快、备受开发者青睐的以太坊 JavaScript 库之一。在本篇文章中,我们将介绍 Ethers.js 的核心功能和用法,包括如何连接区块链节点、与钱包交互、读取智能合约数据、发送交易等。同时,我们还将分享使用 Ethers.js 开发时的最佳实践和易踩的常见坑,帮助你快速上手并避开常见错误。

Ethers.js 简介

Ethers.js 致力于提供一个完整而精简的库,用于与以太坊区块链及其生态系统交互。它涵盖了丰富的功能模块:包括用于连接区块链节点的提供者(Provider)、管理账户和交易签名的签名者(Signer)、简化大数和格式转换的工具库(Utils),以及友好的智能合约调用接口。与传统的 Web3.js 库相比,Ethers.js 的 API 更加简洁优雅,文档完善,因此受到众多开发者的青睐,能够帮助开发者更快速地构建去中心化应用(DApp)。

连接以太坊节点(Provider)

在使用 Ethers.js 时,首先需要一个 Provider 来连接以太坊节点。Provider 负责与区块链通信,获取链上数据或发送交易至网络。Ethers.js 提供了多种 Provider 实现,可以轻松连接以太坊主网、各测试网络(如 Ropsten、Kovan、Goerli 等)或本地开发链。通常,我们会使用像 Infura 或 Alchemy 这类以太坊节点服务提供的 RPC 接口。下面是一个使用 Infura 提供的 Goerli 测试网 RPC 端点创建 Provider 的示例:

// 通过 Infura 的 Goerli 测试网 RPC 接口创建 Provider
const { ethers } = require("ethers");
const INFURA_PROJECT_ID = "你的Infura项目ID";
const provider = new ethers.providers.JsonRpcProvider(`https://goerli.infura.io/v3/${INFURA_PROJECT_ID}`
);

连接钱包与签名(Signer)

要对交易进行签名或执行需要账户权限的操作,我们需要一个 Signer(签名者),它代表一个以太坊账户。Signer 持有私钥,用于对交易进行数字签名。常见的 Signer 来源有两种:一种是在浏览器中通过 MetaMask 等钱包扩展提供账户,另一种是在后端脚本中直接使用私钥创建钱包对象。下面分别给出这两种场景的示例代码。

// 浏览器环境下通过 MetaMask 提供 Signer
const provider = new ethers.providers.Web3Provider(window.ethereum);
// 请确保用户已安装 MetaMask 并在此处请求授权访问账户
await provider.send("eth_requestAccounts", []);
const signer = provider.getSigner();
// Node.js 环境下使用私钥创建 Signer(Wallet)
const { ethers } = require("ethers");
const provider = ethers.getDefaultProvider("goerli");  // 使用默认提供商连接 Goerli 测试网
const PRIVATE_KEY = "你的私钥字符串";
const wallet = new ethers.Wallet(PRIVATE_KEY, provider);

读取区块链数据与智能合约

有了 Provider,我们可以直接读取链上的公共数据,例如账户余额、当前区块号等。例如,调用 provider.getBalance(地址) 可以获取某个地址的以太余额(返回一个大数 BigNumber,单位为 wei)。通常我们会使用 ethers.utils.formatEther() 将其格式化成人类可读的以太值(ETH)。下面是一个查询账户余额并格式化输出的示例:

// 查询指定地址的余额并格式化为 ETH
const userAddress = "0xABC...";  // 要查询的以太坊地址
const balanceBN = await provider.getBalance(userAddress);
console.log("账户余额:", ethers.utils.formatEther(balanceBN), "ETH");

除了基本数据读取,Ethers.js 提供了简便的接口与智能合约交互。要读取合约状态,我们需要合约的地址和 ABI(应用二进制接口)。使用 ethers.Contract 类可以根据地址和 ABI创建合约对象,然后调用其只读方法(ABI 中标记为 view 或 pure 的函数)。例如,下面演示如何获取 ERC-20 代币(如 DAI 稳定币)的名称和某账户的代币余额:

// 与 ERC-20 合约交互示例(以 DAI 稳定币为例)
const daiAddress = "0x6B175474E89094C44Da98b954EedeAC495271d0F"; // DAI 合约地址(以太坊主网)
const daiAbi = ["function name() view returns (string)","function balanceOf(address) view returns (uint256)"
];  // 合约 ABI(这里只列出需要用到的函数)
const daiContract = new ethers.Contract(daiAddress, daiAbi, provider);
const name = await daiContract.name();
const daiBalance = await daiContract.balanceOf(userAddress);
console.log("代币名称:", name);
console.log("账户持有 DAI 数量:", ethers.utils.formatUnits(daiBalance, 18));

发送交易与写入区块链

当需要发送交易(写入链上数据)时,必须使用 Signer 来签署交易。最基础的例子是转账 Ether。我们可以调用 Signer 的 sendTransaction 方法发起转账交易,指定收款方地址和金额(记得使用 ethers.utils.parseEther() 将 ETH 数额转换为 wei)。该方法返回一个交易对象,我们可以使用 await 等待交易发送完成,并进一步调用 tx.wait() 等待其在链上确认。下面代码演示了使用 Signer 转账 0.1 ETH 的过程:

// 假设 wallet 是一个已连接 Provider 的 Signer 对象(例如 new ethers.Wallet(..., provider))
const recipientAddress = "0xDEF...";  // 收款人地址
const tx = await wallet.sendTransaction({to: recipientAddress,value: ethers.utils.parseEther("0.1")  // 转账 0.1 ETH
});
await tx.wait();  // 等待交易被矿工打包确认
console.log("交易已发送,哈希:", tx.hash);

当调用智能合约的状态修改函数时,也需要使用 Signer。可以在创建合约实例时传入 Signer,或使用 contract.connect(signer) 将 Provider 模式的合约实例转换为签名者模式。之后调用例如 await contract.connect(signer).transfer(to, amount) 会返回一个交易对象,与直接使用 Signer 转账类似,需要等待交易确认。

最佳实践

开发者在使用 Ethers.js 时应遵循以下几条最佳实践:

  • 尽量使用测试网络进行开发和调试。例如,可在 Goerli 等测试网部署合约、执行交易,待功能稳定后再切换到主网。
  • 为开发使用单独的测试钱包(也称“burner”钱包),切勿在项目代码或配置中使用存有真实资产的私钥。绝不要将真实资金存入开发测试用的钱包账户。
  • 使用环境变量或配置文件来存放敏感信息(如 Infura API 密钥、私钥等),不要将这些敏感数据硬编码在源码中,也不要将它们提交到代码仓库。
  • 在处理金额数值时,注意以太币的单位换算。善用 ethers.utils.parseEther()、formatEther() 或 formatUnits() 等工具函数来避免精度错误,切勿直接使用浮点数表示 Wei 值。
  • 发送交易后,使用 tx.wait() 等方法等待交易上链确认,确保交易确实被打包成功后再进行后续操作。

易踩的坑

下面是一些初学者在使用 Ethers.js 时常遇到的坑点:

  • 混用 Provider 和 Signer:只有 Signer(带有私钥)才能发送交易或执行链上写操作。如果误将 Provider 当作 Signer 使用(例如调用 provider.sendTransaction),会因缺少签名权限而失败。确保在需要签名的场景下使用正确的 Signer 对象。
  • 忘记使用 await 等待异步结果:Ethers.js 的大部分方法(如读取链上数据、发送交易)都是异步的。如果调用时没有使用 await(或 .then()),将得到一个 Promise 对象,导致后续逻辑出错。例如,忘记 await provider.getBalance() 会导致拿不到实际余额值。
  • 私钥泄漏风险:切勿在前端代码中硬编码私钥,也不要将私钥上传到代码仓库。这会导致严重的安全风险,一旦私钥泄露,攻击者可转移你账户中的所有资产。请使用环境变量管理私钥,并只在可信的后端环境使用它们。
  • 金额单位误差:务必留意 Ether 与 Wei 的单位区别。如果传入交易金额时使用了错误的单位,可能造成金额十万倍的偏差。例如,value: 1 实际发送的是 1 wei(极小的金额),而 ethers.utils.parseEther("1") 才是 1 ETH。

总结

通过以上内容,我们了解到 Ethers.js 提供了简洁而强大的 API 来完成 Web3 开发中的各项操作。从连接节点、交互钱包,到读取合约数据、发送链上交易,Ethers.js 大大降低了与以太坊区块链交互的门槛。掌握了这些基础用法并遵循最佳实践、避开常见陷阱,开发者就能更加自信地使用 Ethers.js 构建出可靠的去中心化应用。

相关文章:

Ethers.js 开发入门:核心功能、最佳实践与避坑指南

引言 Ethers.js 是当前 Web3 开发领域增长最快、备受开发者青睐的以太坊 JavaScript 库之一。在本篇文章中,我们将介绍 Ethers.js 的核心功能和用法,包括如何连接区块链节点、与钱包交互、读取智能合约数据、发送交易等。同时,我们还将分享使…...

SQL查询语句的​​书写顺序​​

一、标准SQL书写顺序(逻辑顺序) 书写顺序是开发者编写SQL时遵循的语法规则,逻辑上更贴近“声明式”需求描述。以下是​​从前往后​​的书写顺序: SELECT[DISTINCT] 列名或表达式 FROM表名或子查询 [JOIN ... ON ...] WHERE行级…...

探索加密期权波动率交易的系统化实践——动态对冲工具使用

Trading Volatility – What Are My Options? 在本文中,我们将介绍一些如何交易资产波动性(而非资产价格)的示例。为了帮助理解,我们将使用 Deribit 上提供的几种不同产品,包括但不限于期权。我们将尽可能消除对标的价…...

文件操作和 IO - 3

目录 文件内容的读写 —— 数据流 InputStream 概述 方法: 说明: FileInputStream 概述 read 方法: OutputStream 概述 方法 说明 FileOutputStream 概述 write 方法: Reader 字符流 Writer 字符流 总结&#xff1a…...

Kubernetes中的Label和Selector核心作用与应用场景

一. Label 和 Selector 的核心概念 Label 和 Selector 是 Kubernetes 中实现灵活资源管理的基石,贯穿部署、服务发现、监控等核心场景。通过合理设计标签,用户可以高效实现自动化运维与精准资源控制。 Label(标签): K…...

L1-6 大勾股定理

题目 大勾股定理是勾股定理的推广:对任何正整数 n 存在 2n1 个连续正整数,满足前 n1 个数的平方和等于后 n 个数的平方和。例如对于 n1 有 3^2 4^2 5^2 ;n2 有 10^2 11^2 12^2 13^2 14^2 等。给定 n,本题就请你找出对应的解。 输…...

esp32-idf Linux 环境安装教程

一、提前说明 1. 系统环境 Ubuntu22.04 2. 适配芯片 ESP32S3 3. idf版本 v5.4.1(截止2025年4月13日为最新版本) 二、安装步骤 1. 安装前置依赖 sudo apt-get install git wget flex bison gperf python3 python3-pip python3-venv cmake ninja-build ccache libffi-dev l…...

关于使用 nuitka进行构建python应用的一些配置,以及github action自动构建;

1. 通用配置 # 设置输出目录和文件名output_dir "dist"app_name "CursorAutoFree"# 基础命令行选项base_options ["--follow-imports", # 跟踪导入"--enable-plugintk-inter", # 启用 Tkinter 支持"--include-packagecusto…...

C++开山解惑

. Solution & Code 本题解仅适用于 C 选手。 这道题可谓是 C 中最基础的题目之一&#xff0c;先上两份代码&#xff1a; #include <cstdio> using namespace std;int main() {long long a, b;scanf("%lld%lld", &a, &b);printf("%lld"…...

Pytorch深度学习框架60天进阶学习计划 - 第41天:生成对抗网络进阶(二)

Pytorch深度学习框架60天进阶学习计划 - 第41天&#xff1a;生成对抗网络进阶&#xff08;二&#xff09; 7. 实现条件WGAN-GP # 训练条件WGAN-GP def train_conditional_wgan_gp():# 用于记录损失d_losses []g_losses []# 用于记录生成样本的多样性&#xff08;通过类别分…...

路由策略/策略路由之route-policy

思科名称&#xff1a;route-map、match、set Route-policy 是一个非常重要的基础性策略工具。你可以把它想象成一个拥有多个节点&#xff08;node&#xff09;的列表&#xff08;这些 node 按编号大小进行排序&#xff09;。在每个节点中&#xff0c;可以定义条件语句及执行语…...

《嵌入式系统原理》一些题目

1 &#xff0e;ARM 的存储格式&#xff1f;默认的存储模式是&#xff1f; 大端格式和小端格式&#xff0c;默认为小端模式 2 &#xff0e;当前程序状态寄存器&#xff1f;&#xff08;英文简写、条件码标志位及控制位的含义&#xff09; CPSR&#xff0c;N,Z,C,V(P26) 3 &a…...

卡洛诗已悄然改写高性价比西餐的竞争规则

在餐饮行业竞争日益激烈的今天&#xff0c;消费者对“高性价比”的定义已从单纯的低价转向品质、体验与情感价值的综合考量。萨莉亚原团队成员出来升级孵化的新概念中式西餐卡洛诗以“访九州异馔&#xff0c;再造东方味”为核心理念&#xff0c;通过本土化创新、严控文化及场景…...

独立开发者之网站的robots.txt文件如何生成和添加

robots.txt是一个存放在网站根目录下的文本文件&#xff0c;用于告诉搜索引擎爬虫哪些页面可以抓取&#xff0c;哪些页面不可以抓取。下面我将详细介绍如何生成和添加robots.txt文件。 什么是robots.txt文件&#xff1f; robots.txt是遵循"机器人排除协议"(Robots…...

02核心-EffectSpec,EffectContext

1.FGameplayEffectSpec 效果Spec 创建&#xff1a;MakeOutGoingSpec>EffectSpecHandle≈EffectSpec. 创建总结&#xff1a;EffectLevelEffectContext>EffectSpec(Handle) 数据&#xff1a;EffectSpec存有效果的等级&#xff0c;上下文&#xff0c;类。 还有很多其他东…...

驱动开发硬核特训 · Day 10(下篇):设备模型实战篇 —— Platform 驱动机制 ≈ 运行时适配器

&#x1f50d; B站相应的视屏教程&#xff1a; &#x1f4cc; 内核&#xff1a;博文视频 - 总线驱动模型实战全解析 敬请关注&#xff0c;记得标为原始粉丝。 &#x1f527; &#x1f4cd; 一、目标与回顾 在上篇《理论篇》中&#xff0c;我们从软件工程角度&#xff0c;解释…...

集合框架二三事

一.集合框架 Java集合框架&#xff08;Java Collections Framework&#xff09;是Java标准库中用于存储和处理对象集合的一组接口和实现类。它提供了一套统一的API&#xff0c;使得开发者能够高效地管理和操作数据集合。以下是关于Java集合框架的详细介绍&#xff0c;包括其核…...

前端jest(vitest)单元测试快速手上

前言 vitest和jest除了配置上不同&#xff0c;其他的基本差不多&#xff0c;这里以jest为例进行说明 安装依赖 npm install -D jest编写测试 例如&#xff0c;我们将编写一个简单的测试来验证将两个数字相加的函数的输出。 sum.js export function sum(a, b) {return a b…...

优化方法介绍(二)

优化方法介绍(二) 本博客是一个系列博客,主要是介绍各种优化方法,使用 matlab 实现,包括方法介绍,公式推导和优化过程可视化 1 BFGS 方法介绍 BFGS 的其实就是一种改良后的牛顿法,因为计算二阶导数 Hessian 矩阵所需的计算资源是比较大的,复杂度为 O ( 2 ⋅ n 2 ) …...

Sklearn入门之datasets的基本用法

、 Sklearn全称:Scipy-toolkit Learn是 一个基于scipy实现的的开源机器学习库。它提供了大量的算法和工具&#xff0c;用于数据挖掘和数据分析&#xff0c;包括分类、回归、聚类等多种任务。本文我将带你了解并入门Sklearn下的datasets在机器学习中的基本用法。 获取方式 pi…...

UDS协议 - 应用层服务测试用例概览

目录 前言一、10服务物理寻址测试功能寻址测试二、11服务物理寻址测试功能寻址测试三、14服务物理寻址测试功能寻址测试四、19服务物理寻址测试功能寻址测试五、22服务物理寻址测试功能寻址测试六、27服务物理寻址测试七、28服务物理寻址测试功能寻址测试八、2E服务物理寻址测试…...

记录一个虚拟机分配资源的问题

Virtualize Intel VT - x/EPT or AMD - V/RVI&#xff1a;若物理机的 CPU 支持对应的硬件虚拟化技术&#xff08;Intel VT - x 或 AMD - V&#xff09;&#xff0c;强烈建议开启。该功能可显著提升虚拟机的性能&#xff0c;让虚拟机更高效地利用物理 CPU 资源&#xff0c;改善卡…...

(即插即用模块-特征处理部分) 三十一、(2024) CDFA 对比度驱动的特征聚合模块

文章目录 1、Contrast-Driven Feature Aggregation module2、代码实现 paper&#xff1a;ConDSeg: A General Medical Image Segmentation Framework via Contrast-Driven Feature Enhancement Code&#xff1a;https://github.com/Mengqi-Lei/ConDSeg 1、Contrast-Driven Feat…...

机械革命 无界15X 自带的 有线网卡 YT6801 debian12下 的驱动方法

这网卡是国货啊。。。 而且人家发了驱动程序 Motorcomm Microelectronics. YT6801 Gigabit Ethernet Controller [1f0a:6801] 网卡YT6801在Linux环境中的安装方法 下载网址 yt6801-linux-driver-1.0.29.zip 我不知道别的系统是否按照说明安装就行了 但是debian12不行&…...

TypeScript 的 interface 接口

TypeScript 的 interface 接口 简介 interface 是对象的模板&#xff0c;可以看作是一种类型约定&#xff0c;中文译为“接口”。使用了某个模板的对象&#xff0c;就拥有了指定的类型结构。 interface Person {firstName: string;lastName: string;age: number;} 上面示例中…...

SpringBoot3-web开发笔记(下)

内容协商 实现&#xff1a;一套系统适配多端数据返回 多端内容适配&#xff1a; 1. 默认规则 SpringBoot 多端内容适配。 基于请求头内容协商&#xff1a;&#xff08;默认开启&#xff09; 客户端向服务端发送请求&#xff0c;携带HTTP标准的Accept请求头。 Accept: applica…...

关于无线网络安全的基础知识,涵盖常见威胁、防护措施和实用建议

无线网络(WiFi)的普及极大地方便了我们的生活,但其开放性也带来了诸多安全隐患。以下是关于无线网络安全的基础知识,涵盖常见威胁、防护措施和实用建议: 一、无线网络常见安全威胁 窃听(Eavesdropping) 攻击者通过监听无线信号,截获未加密的数据(如登录密码、聊天记录…...

《基于 RNN 的股票预测模型代码优化:从重塑到直接可视化》

在深度学习领域&#xff0c;使用循环神经网络&#xff08;RNN&#xff09;进行股票价格预测是一个常见且具有挑战性的任务。本文将围绕一段基于 RNN 的股票预测代码的改动前后差别展开&#xff0c;深入剖析代码的优化思路和效果。 原始代码思路与问题 原始代码实现了一个完整…...

【leetcode刷题日记】lc.347-前 K 个高频元素

目录 1.题目 2.代码 1.题目 给你一个整数数组 nums 和一个整数 k &#xff0c;请你返回其中出现频率前 k 高的元素。你可以按 任意顺序 返回答案。 示例 1: 输入: nums [1,1,1,2,2,3], k 2 输出: [1,2]示例 2: 输入: nums [1], k 1 输出: [1] 提示&#xff1a; 1 <…...

进程I·介绍、查看、创建与状态

目录 介绍 PCB&#xff08;进程控制块&#xff09; task_struct 查看、创建进程 进程状态 小知识 介绍 进程&#xff1a;PCB&#xff08;process control block&#xff09;&#xff08;内核数据结构&#xff09; 代码和数据 进程创建&#xff1a;操作系统将其相关属性信…...

[k8s]随笔- spec内容整理

面对 Kubernetes 中 spec 字段的复杂性&#xff0c;关键在于建立 层次化的分类逻辑 和 功能导向的归纳方法。以下是具体的规整思路和实践步骤&#xff0c;帮助你理清脉络、高效使用&#xff1a; 一、按资源类型分层&#xff1a;先分“大类”&#xff0c;再钻“细节” K8s 资源…...

程序化广告行业(81/89):行业术语解析与日常交流词汇指南

程序化广告行业&#xff08;81/89&#xff09;&#xff1a;行业术语解析与日常交流词汇指南 在程序化广告这个不断发展的行业中&#xff0c;持续学习和知识共享是我们紧跟潮流、提升能力的关键。一直以来&#xff0c;我都希望能和大家一起探索这个领域&#xff0c;共同进步。今…...

层归一化(Layer Normalization) vs 批量归一化(Batch Normalization)

层归一化和批量归一化都是 归一化方法,目的是让训练更稳定、收敛更快,但应用场景和工作方式大不相同。 名称一句话解释BatchNorm对 同一通道、不同样本之间 做归一化,适合图像任务,依赖 Batch Size。LayerNorm对 每个样本自身所有特征维度 做归一化,适合序列任务,不依赖 …...

【杂谈】-开源 AI 的复兴:Llama 4 引领潮流

开源 AI 的复兴&#xff1a;Llama 4 引领潮流 文章目录 开源 AI 的复兴&#xff1a;Llama 4 引领潮流一、Llama 4&#xff1a;开源 AI 的挑战者二、真实利他还是战略布局&#xff1f;三、对开发者、企业和人工智能未来的启示 在过去的几年里&#xff0c;AI 领域发生了重大转变。…...

instructor 库实现缓存

目录 代码代码解释1. 基础设置2. 客户端初始化3. 数据模型定义4. 缓存设置5. 缓存装饰器6. 示例函数工作流程 示例类似例子 代码 import functools import inspect import instructor import diskcachefrom openai import OpenAI, AsyncOpenAI from pydantic import BaseModel…...

【日志链路】⭐️SpringBoot 整合 TraceId 日志链路追踪!

&#x1f4a5;&#x1f4a5;✈️✈️欢迎阅读本文章❤️❤️&#x1f4a5;&#x1f4a5; &#x1f3c6;本篇文章阅读大约耗时6分钟。 ⛳️motto&#xff1a;不积跬步、无以千里 &#x1f4cb;&#x1f4cb;&#x1f4cb;本文目录如下&#xff1a;&#x1f381;&#x1f381;&am…...

QT6 源(16):存储 QT 里元对象的类信息的类 QMetaClassInfo 的类,只有两个成员函数 name()、value(),比元对象属性简单多了

&#xff08;1&#xff09;所在头文件 qmetaobject.h &#xff1a; class Q_CORE_EXPORT QMetaClassInfo { private: //private 属性里包含了至关重要的数据成员的定义&#xff0c;放前面struct Data {enum { Size 2 };const uint * d; //包含了数组的起始地址uint name ()…...

deskflow使用教程:一个可以让两台电脑鼠标键盘截图剪贴板共同使用的开源项目

首先去开源网站下载&#xff1a;Release v1.21.2 deskflow/deskflow 两台电脑都要下载这个文件 下载好后直接打开找到你想要的exe desflow.exe 然后你打开他&#xff0c;将两台电脑的TLS都关掉 下面步骤两台电脑都要完成&#xff1a; 电脑点开edit-》preferences 把这个取…...

波束形成(BF)从算法仿真到工程源码实现-第六节-广义旁瓣消除算法(GSC)

一、概述 本节我们讨论广义旁瓣消除算法(GSC)&#xff0c;包括原理分析及代码实现。 更多资料和代码可以进入https://t.zsxq.com/qgmoN &#xff0c;同时欢迎大家提出宝贵的建议&#xff0c;以共同探讨学习。 二、原理分析 广义旁瓣消除(GSC)算法 GSC算法是与LCMV算法等效的&…...

企业数字化转型需要注重的深层维度:生成式AI时代的战略重构

企业数字化转型正在经历从"技术适配"到"基因重组"的质变。生成式AI技术的突破性发展,要求企业超越传统信息化框架,构建全新的数字化转型认知体系。本文将从战略认知、技术融合、组织进化、伦理治理、生态协作五个维度,系统解构企业数字化转型需注重的核…...

图论之并查集——含例题

目录 介绍 秩是什么 例子——快速入门 例题 使用路径压缩&#xff0c;不使用秩合并 使用路径压缩和秩合并 无向图和有向图 介绍 并查集是一种用于 处理不相交集合的合并与查询问题的数据结构。它主要涉及以下基本概念和操作&#xff1a; 基本概念&#xff1a; 集合&…...

解释型语言和编译型语言的区别

Python 的执行过程通常涉及字节码&#xff0c;而不是直接将代码编译为机器码。以下是详细的解释&#xff1a; ### **Python 的执行过程** 1. **源代码到字节码**&#xff1a; - Python 源代码&#xff08;.py 文件&#xff09;首先被编译为字节码&#xff08;.pyc 文件&…...

零基础上手Python数据分析 (14):DataFrame 数据分组与聚合 - 玩转数据透视,从明细到洞察

写在前面 —— 像搭积木一样分析数据,掌握Pandas GroupBy,轻松实现分组统计与聚合 回顾一下,上篇博客我们学习了如何使用 Pandas 合并与连接多个 DataFrame,将分散的数据整合到一起。 现在,我们拥有了更完整、更丰富的数据视图。 接下来,一个非常常见的分析需求就是 对…...

Honor of Kings (S39) 13-win streak

Honor of Kings (S39) 13-win streak S39赛季13连胜&#xff0c;庄周&#xff0c;廉颇硬辅助&#xff0c;对面有回血就先出红莲斗盆&#xff0c;有遇到马克没带净化的&#xff0c;出【冰霜冲击】破他大招 S39&#xff0c;庄周廉颇前排硬辅助全肉全堆血13连胜_哔哩哔哩bilibi…...

输出流-----超级详细的在程序中向文件.txt中写入内容

1.使用Fileoutputstream对象&#xff0c;如果在目录中已经存在该文件&#xff0c;那么将不会在创建&#xff0c;如果该目录中没有该文件&#xff0c;那么将会自动创建文件。 2.在目录中a.txt文件中写入一个h字符&#xff0c;这种方式是写入单个字符。 //在目录中a.txt文件中写入…...

【Mysql】死锁问题详解

【Mysql】死锁问题详解 【一】Mysql中锁分类和加锁情况【1】按锁的粒度分类&#xff08;1&#xff09;全局锁&#xff08;2&#xff09;表级锁1、表共享读锁&#xff08;Table Read Lock&#xff09;2、表独占写锁&#xff08;Table Write Lock&#xff09;3、元数据锁&#xf…...

C语言实现用户管理系统

以下是一个简单的C语言用户管理系统示例&#xff0c;它实现了用户信息的添加、删除、修改和查询功能。代码中包含了详细的注释和解释&#xff0c;帮助你理解每个部分的作用。 #include <stdio.h> #include <stdlib.h> #include <string.h>#define MAX_USERS…...

SAP BDC:企业数据管理的新纪元

2025年4月&#xff0c;SAP在纽约发布了其全新企业数据平台——Business Data Cloud&#xff08;BDC&#xff09;&#xff0c;标志着企业数据管理和AI集成战略的重大升级。BDC不仅整合了SAP内部和外部的结构化与非结构化数据&#xff0c;还借助与Databricks的合作&#xff0c;推…...

数学建模学习资料免费分享:历年赛题与优秀论文、算法课程、数学软件等

本文介绍并分享自己当初准备数学建模比赛时&#xff0c;收集的所有资料&#xff0c;包括历年赛题与论文、排版模板、算法讲解课程与书籍、评分标准、数学建模软件等各类资料。 最近&#xff0c;准备将自己在学习过程中&#xff0c;到处收集到的各类资料都整理一下&#xff0c;并…...

计算机的运算方式

1. 计算机运算的基本概念 计算机的运算由 算术逻辑单元&#xff08;ALU&#xff09; 执行&#xff0c;其核心功能是完成 算术运算 和 逻辑运算。所有运算均基于二进制编码&#xff0c;通过硬件电路实现高速计算。 运算对象&#xff1a;二进制数&#xff08;定点数、浮点数&am…...