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

5.【Python】Python3 运算符

第一步分析与整理 运算符1. 什么是运算符运算符用于执行算术、比较、逻辑等操作。操作数是参与运算的值。例如4 5 9中4和5是操作数是运算符。Python 支持以下运算符类型算术运算符比较关系运算符赋值运算符逻辑运算符位运算符成员运算符身份运算符运算符优先级2. 算术运算符假设a10b21运算符描述实例加a b→ 31-减a - b→ -11*乘a * b→ 210/除浮点数b / a→ 2.1%取模余数b % a→ 1**幂a ** b→ 10^21//整除向下取整9//2→ 4-9//2→ -5示例代码a21b10c0cabprint(1 - c 的值为,c)# 31ca-bprint(2 - c 的值为,c)# 11ca*bprint(3 - c 的值为,c)# 210ca/bprint(4 - c 的值为,c)# 2.1ca%bprint(5 - c 的值为,c)# 1a2b3ca**bprint(6 - c 的值为,c)# 8a10b5ca//bprint(7 - c 的值为,c)# 23. 比较运算符假设a10b20运算符描述实例等于(a b)→ False!不等于(a ! b)→ True大于(a b)→ False小于(a b)→ True大于等于(a b)→ False小于等于(a b)→ True示例代码a21b10ifab:print(1 - a 等于 b)else:print(1 - a 不等于 b)# 输出ifa!b:print(2 - a 不等于 b)# 输出# ... 其余类似4. 赋值运算符运算符描述实例简单赋值c a b加法赋值c a→c c a-减法赋值c - a*乘法赋值c * a/除法赋值c / a%取模赋值c % a**幂赋值c ** a//整除赋值c // a:海象运算符3.8在表达式中赋值并返回值海象运算符示例# 传统写法n10ifn5:print(n)# 海象运算符if(n:10)5:print(n)# 10优点减少重复计算提高可读性。例如避免调用len()两次if(n:len(a))10:print(fList is too long ({n}elements, expected 10))5. 位运算符将数字视为二进制进行运算。假设a 600011 1100b 130000 1101运算符描述实例按位与a b→ 12 (0000 1100)|按位或a | b→ 61 (0011 1101)^按位异或a ^ b→ 49 (0011 0001)~按位取反~a→ -61补码表示左移a 2→ 240 (1111 0000)右移a 2→ 15 (0000 1111)示例代码a60b13cabprint(1 - c 的值为,c)# 12ca|bprint(2 - c 的值为,c)# 61ca^bprint(3 - c 的值为,c)# 49c~aprint(4 - c 的值为,c)# -61ca2print(5 - c 的值为,c)# 240ca2print(6 - c 的值为,c)# 156. 逻辑运算符假设a10b20运算符描述实例and布尔“与”(a and b)→ 20or布尔“或”(a or b)→ 10not布尔“非”not(a and b)→ False注意and和or返回的是操作数的值而不是简单的True/False。短路求值。a10b20ifaandb:print(a 和 b 都为 true)# 输出7. 成员运算符运算符描述实例in在序列中找到值返回 Truea in listnot in在序列中未找到值返回 Trueb not in listlist[1,2,3,4,5]a10ifainlist:print(a 在列表中)else:print(a 不在列表中)# 输出8. 身份运算符比较两个对象的内存地址是否为同一个对象。运算符描述实例is引用同一对象返回 Truea is bis not引用不同对象返回 Truea is not bis与区别is判断对象身份id 是否相同判断值是否相等a[1,2,3]baprint(bisa)# Trueba[:]print(bisa)# Falseprint(ba)# True9. 运算符优先级从高到低相同单元格内从左至右幂运算从右至左优先级运算符最高(expressions...),[expressions...],{key:value...}x[index],x[index:index],x(arguments...),x.attributeawait x**x,-x,~x*,,/,//,%,-,^|in,not in,is,is not,,,,,!,not xandorif -- elselambda最低:示例a20b10c15d5e(ab)*c/d# (30*15)/5 90.0print(e)and 优先级高于 orxTrueyFalsezFalseifxoryandz:# 等同于 x or (y and z)print(yes)# 会输出if(xory)andz:print(yes)# 不会输出注Python 3 已不支持运算符应使用!。如需使用可from __future__ import barry_as_FLUFL。第二步费曼学习法教学核心思想运算符就是让电脑帮你做各种“计算动作”编程中我们经常需要对数据进行处理加减乘除、比较大小、判断真假、移动二进制位等等。运算符就是告诉电脑“请执行这个动作”的符号。1. 算术运算符最基础的数学计算,-,*,/和数学课上学的一样。%是“取余数”10 % 3 1常用于判断奇偶、循环索引。//是“整除向下取整”9//24-9//2-5注意是向负无穷取整不是截断。**是幂运算2**101024比pow(2,10)更简洁。容易忽略的点/总是返回浮点数即使两个整数都能整除。如果需要整数结果用//。2. 比较运算符得到 True/False用于条件判断。常见陷阱赋值与相等混淆。!表示不等于。3. 赋值运算符把计算结果存起来是赋值。这类“增强赋值”让代码更紧凑x 1比x x 1更清晰。海象运算符:在表达式中同时赋值并返回值。典型用途是避免重复计算# 不用海象需要计算两次 len(a)iflen(a)10:print(f长度{len(a)}大于10)# 用海象只计算一次if(n:len(a))10:print(f长度{n}大于10)4. 位运算符直接操作二进制位虽然平时用得少但在芯片验证、网络协议、嵌入式等领域非常重要。例如用于掩码提取某些位|用于设置位^用于翻转位,用于快速乘以/除以 2 的幂。例子判断一个整数是否为 2 的幂(n (n-1)) 05. 逻辑运算符组合条件and两边都为真才真。or至少一边为真即真。not取反。注意短路False and anything不计算 anythingTrue or anything不计算 anything。利用短路可以写出简洁的代码例如x and print(x)。6. 成员运算符检查是否在集合中in和not in对字符串、列表、元组、字典检查键都有效。非常常用。7. 身份运算符判断是不是同一个对象is用于比较None、单例对象。不要用is来比较数字或字符串可能因小整数缓存而偶然相等但不可靠。比较值is比较身份。aNoneifaisNone:# 正确写法8. 运算符优先级不用死记硬背用括号优先级决定了哪个运算符先计算。例如*先于。当你记不清时加括号( )明确意图还能提高可读性。常见优先级错误ifab0:# 实际是 a (b 0)可能不是你想要的if(ab)0:# 正确如何学习与应用多动手在交互式环境里测试每个运算符。结合现实问题写一个计算器、判断闰年、位图操作。工作中验证工程师常用位运算处理寄存器掩码、用成员运算符检查仿真日志中的关键词、用海象运算符优化循环。综合示例简单的位掩码工具defset_bit(value,pos):将 value 的第 pos 位设为 1pos 从 0 开始returnvalue|(1pos)defclear_bit(value,pos):将 value 的第 pos 位设为 0returnvalue~(1pos)deftest_bit(value,pos):测试第 pos 位是否为 1return(valuepos)1# 使用示例reg0b1010regset_bit(reg,1)# 现在 1010 - 1010? 实际第1位已是1不变regclear_bit(reg,3)# 清除第3位: 1010 - 0010 (二进制)print(bin(reg))# 0b10print(test_bit(reg,1))# 1第三步芯片验证工程师视角的应用示例在芯片验证中我们经常需要解析硬件寄存器描述、生成随机测试向量、检查状态位等。位运算符和逻辑运算符是必备工具。下面给出一个模拟寄存器读写与位域操作的示例。场景描述你有一个 32 位控制寄存器CTRL_REG其位域定义如下bit[0]: 使能位 (EN)bit[3:1]: 模式字段 (MODE)3位bit[7:4]: 分频系数 (DIV)4位bit[31:8]: 保留需要编写函数来读取/修改这些位域并验证随机生成的配置是否符合预期。# filename: reg_operations.py# 功能模拟硬件寄存器位域操作用于验证环境classRegister:简单的寄存器抽象支持位域读写def__init__(self,name,width32,value0):self.namename self.widthwidth self._valuevalue((1width)-1)# 截断到指定位宽defread(self):returnself._valuedefwrite(self,value):self._valuevalue((1self.width)-1)returnself._valuedefget_field(self,high,low):提取 [high:low] 位域的值包含 high 和 lowmask((1(high-low1))-1)lowreturn(self._valuemask)lowdefset_field(self,high,low,field_value):设置 [high:low] 位域为 field_value保留其他位mask((1(high-low1))-1)low# 清空原字段再或上新的值self._value(self._value~mask)|((field_valuelow)mask)returnself._valuedef__repr__(self):returnf{self.name}0x{self._value:0{self.width//4}X}# 定义 CTRL_REG 的位域CTRL_EN_POS0CTRL_EN_MASK1CTRL_EN_POS CTRL_MODE_LOW1CTRL_MODE_HIGH3CTRL_MODE_MASK((1(CTRL_MODE_HIGH-CTRL_MODE_LOW1))-1)CTRL_MODE_LOW CTRL_DIV_LOW4CTRL_DIV_HIGH7CTRL_DIV_MASK((1(CTRL_DIV_HIGH-CTRL_DIV_LOW1))-1)CTRL_DIV_LOWdeftest_reg_operations():测试寄存器位域操作ctrlRegister(CTRL_REG,32,0x0000_0000)# 1. 使能位设置ctrl.set_field(CTRL_EN_POS,CTRL_EN_POS,1)print(ctrl)# CTRL_REG0x00000001enctrl.get_field(CTRL_EN_POS,CTRL_EN_POS)print(fEN {en})# 1# 2. 设置模式为 5 (二进制 101)ctrl.set_field(CTRL_MODE_HIGH,CTRL_MODE_LOW,5)print(ctrl)# 应该是 bit3-1 101整体 0x...0A? 计算bit11,bit20,bit31 - 0b1010 1? 实际值 (51)10 (0xA) 1 11 (0xB)print(fMode {ctrl.get_field(CTRL_MODE_HIGH,CTRL_MODE_LOW)})# 5# 3. 设置分频系数为 8 (4位最大15)ctrl.set_field(CTRL_DIV_HIGH,CTRL_DIV_LOW,8)print(ctrl)# 现在 bit7-4 1000 (8)divctrl.get_field(CTRL_DIV_HIGH,CTRL_DIV_LOW)print(fDIV {div})# 8# 4. 验证总体寄存器值是否符合预期使用位运算直接比较expected(1CTRL_EN_POS)|(5CTRL_MODE_LOW)|(8CTRL_DIV_LOW)ifctrl.read()expected:print(寄存器值正确)else:print(f错误: 寄存器0x{ctrl.read():X}, 期望0x{expected:X})defgenerate_random_config():随机生成有效的寄存器配置用于仿真激励importrandom enrandom.choice([0,1])moderandom.randint(0,7)# 3位0-7divrandom.randint(0,15)# 4位0-15reg_val(enCTRL_EN_POS)|(modeCTRL_MODE_LOW)|(divCTRL_DIV_LOW)returnreg_valdefcheck_config_valid(reg_val):检查随机配置是否符合约束例如分频系数不能为0div(reg_valCTRL_DIV_LOW)((1(CTRL_DIV_HIGH-CTRL_DIV_LOW1))-1)ifdiv0:returnFalse,分频系数不能为0# 模式不能为保留值 7假设mode(reg_valCTRL_MODE_LOW)0x7ifmode7:returnFalse,模式7是保留值returnTrue,有效if__name____main__:test_reg_operations()print(\n--- 随机配置测试 ---)for_inrange(10):cfggenerate_random_config()valid,msgcheck_config_valid(cfg)print(f配置: 0x{cfg:08X}-{msg})详解验证工程师角度位运算符在寄存器操作中的核心作用左移将位域值移到正确的位置。|按位或合并多个位域。按位与提取或清零特定位。~按位取反构造清零掩码。复合使用(reg ~mask) | (value low)是标准位域赋值模式。为什么要抽象成类提高代码复用性避免在每个地方重复编写掩码计算。便于维护修改位域定义只需改一处。可以扩展为带读写回调的模型用于仿真环境中的寄存器模型RAL。实际工作中的应用验证环境中的寄存器抽象层RAL使用类似方法模拟 DUT 寄存器行为。生成随机测试序列generate_random_config用于覆盖率驱动的随机测试。检查约束条件check_config_valid确保随机值不会产生非法配置。学习建议先手动计算小位宽如 8 位的掩码理解((1 n) - 1)为什么能得到 n 个 1。在 Python 交互环境中测试每个位运算表达式观察结果。尝试为自己的项目例如一个简单的 CPU 或外设模型编写寄存器位域操作。通过这个实战示例你将深刻理解位运算符、赋值运算符、逻辑运算符和成员运算符在芯片验证中的价值。运算符虽小却是构建复杂自动化工具的基础砖石。

相关文章:

5.【Python】Python3 运算符

第一步:分析与整理 运算符1. 什么是运算符? 运算符用于执行算术、比较、逻辑等操作。操作数是参与运算的值。例如 4 5 9 中,4 和 5 是操作数, 是运算符。 Python 支持以下运算符类型: 算术运算符比较(关系…...

晶圆为何是圆形而芯片是方形?揭秘半导体制造的工程智慧

1. 项目概述:一个看似简单却充满工程智慧的谜题“为什么晶圆是圆的,而芯片是方的?” 这个问题,乍一听像是半导体行业里一个有趣的脑筋急转弯,但它背后却串联起了从材料科学、物理化学到精密制造、经济学乃至数学几何的…...

基于MCP协议实现AI安全访问MongoDB:架构、部署与安全实践

1. 项目概述与核心价值最近在折腾AI应用开发,特别是想让大语言模型(LLM)能直接操作数据库,比如MongoDB。这听起来很酷,对吧?想象一下,你直接告诉AI助手“帮我查一下上个月销量最高的产品”&…...

SISSO 终极指南:数据驱动建模的强大工具

SISSO 终极指南:数据驱动建模的强大工具 【免费下载链接】SISSO A data-driven method combining symbolic regression and compressed sensing for accurate & interpretable models. 项目地址: https://gitcode.com/gh_mirrors/si/SISSO SISSO&#xf…...

【嵌入式 AI 实战第 9 期】环境感知(一)气体传感器阵列与数据采集(附完整 C 语言驱动)

一、前言在物联网与人工智能快速发展的今天,环境感知能力已成为智能设备的核心功能之一。气体传感器作为环境感知的 "嗅觉器官",广泛应用于智能家居、工业安全、农业生产、医疗诊断等领域。传统的单一气体传感器只能检测特定类型的气体&#x…...

ViGEmBus:终极Windows游戏控制器模拟解决方案,彻底改变游戏输入体验

ViGEmBus:终极Windows游戏控制器模拟解决方案,彻底改变游戏输入体验 【免费下载链接】ViGEmBus Windows kernel-mode driver emulating well-known USB game controllers. 项目地址: https://gitcode.com/gh_mirrors/vi/ViGEmBus 在游戏开发和输入…...

从 API 密钥管理角度看 Taotoken 控制台提供的安全与便捷性

🚀 告别海外账号与网络限制!稳定直连全球优质大模型,限时半价接入中。 👉 点击领取海量免费额度 从 API 密钥管理角度看 Taotoken 控制台提供的安全与便捷性 1. 引言:集中管理的起点 在开发涉及大模型的应用时&#…...

LLM从零到英雄:四阶段学习路径与实战指南

1. 项目概述:从零到英雄的LLM学习之旅最近在GitHub上看到一个挺有意思的项目,叫“LLMs-Zero-to-Hero”。光看名字就挺带劲的,直译过来就是“大语言模型:从零到英雄”。这项目定位非常清晰,就是给那些想入门大语言模型&…...

Adafruit IO物联网平台:从零构建环境监测与报警系统

1. 项目概述:为什么你需要一个像Adafruit IO这样的物联网平台?如果你玩过Arduino、树莓派或者任何单片机,肯定遇到过这样的场景:费了老大劲写代码让传感器读出数据,结果这些数据要么在串口监视器里一闪而过&#xff0c…...

OpenPencil Design Orchestrator:打通设计与代码的设计系统自动化工具

1. 项目概述:从开源仓库名到设计编排器的深度解读看到sorrowfulnessstaff973/openpencil-design-orchestrator这个仓库名,很多人的第一反应可能是好奇和困惑。这串字符背后,究竟隐藏着一个怎样的项目?作为一名长期混迹于开源社区、…...

基于英创ARM9嵌入式主板实现双CAN接口的硬件设计与Linux驱动配置实战

1. 项目概述:为什么需要双CAN接口? 在工业自动化、汽车电子、新能源设备这些领域里,CAN总线就像设备之间的“神经系统”,负责传递各种控制指令和状态数据。一个CAN接口是基础,但当你需要同时连接两个独立的CAN网络&…...

基于Adafruit TRRS Trinkey构建低成本无障碍鼠标键盘模拟器与开关控制器

1. 项目概述:为无障碍交互打开一扇新窗在数字时代,鼠标和键盘是我们与计算机交互最直接的桥梁。然而,对于许多因运动神经元疾病、脊髓损伤、脑瘫或其他肢体障碍而无法使用传统输入设备的朋友来说,这座桥梁却显得遥不可及。作为一名…...

PD SINK芯片选型指南:从核心参数到实战场景的深度解析

1. 项目概述:为什么PD SINK芯片选型是门技术活最近在做一个带Type-C充电口的便携设备项目,客户明确要求必须支持主流的快充协议,尤其是USB PD。这让我不得不重新审视一个看似简单、实则暗藏玄机的环节:PD SINK协议芯片的选型。你可…...

STM32F4的CAN总线配置避坑指南:从原理图到500Kbps通信的完整流程

STM32F4的CAN总线配置避坑指南:从原理图到500Kbps通信的完整流程 CAN总线作为工业控制领域的经典通信协议,在STM32F4系列开发中却常因硬件设计盲区和软件配置细节导致通信失败。本文将带您穿越从原理图设计到稳定实现500Kbps通信的全流程,重点…...

091、力控制:阻抗控制与导纳控制

091 力控制:阻抗控制与导纳控制 从一次机器人撞坏夹具说起 去年调试一台六轴协作机器人,做精密装配。力控参数调了一周,结果在某个姿态下,机器人突然“发疯”,直接把气动夹具怼变形了。事后复盘,发现是阻抗控制里的刚度矩阵设错了——不是数值大小的问题,是坐标系搞反…...

OpenAgents:从零构建数据驱动的AI智能体平台实战指南

1. 项目概述:当AI不只是聊天,而是能替你“干活”的智能体最近在AI圈子里,一个名为“OpenAgents”的项目热度持续攀升。它不是一个简单的聊天机器人,也不是一个封闭的单一应用。简单来说,OpenAgents是一个开源的、数据驱…...

TouchGFX SPI屏移植避坑全记录:从下载算法到分散加载.sct文件

TouchGFX SPI屏移植实战:破解下载算法与分散加载的三大技术难点 当一块240x320的SPI接口屏幕在STM32F412RET6上流畅渲染出60帧的TouchGFX界面时,我盯着示波器上稳定的时序信号长舒一口气——这已经是本周第三次重写W25Q64的下载算法。与官方文档描述的&…...

如何快速打造专业直播画面:OBS StreamFX插件终极指南

如何快速打造专业直播画面:OBS StreamFX插件终极指南 【免费下载链接】obs-StreamFX StreamFX is a plugin for OBS Studio which adds many new effects, filters, sources, transitions and encoders! Be it 3D Transform, Blur, complex Masking, or even custom…...

手把手教你用TTL线刷救活咪咕MGV3200盒子(GK6323V100C芯片/安卓9系统)

咪咕MGV3200盒子救砖全指南:从TTL焊接到底层刷机实战 当你的咪咕MGV3200电视盒子因为一次鲁莽的卡刷操作变成"砖头",指示灯不再亮起,屏幕一片漆黑时,那种绝望感只有经历过的人才能体会。不同于普通刷机教程,…...

基于RAG架构构建私有知识库智能问答系统:从原理到部署实战

1. 项目概述:一个基于内容的智能对话机器人最近在GitHub上看到一个挺有意思的项目,叫mpaepper/content-chatbot。乍一看名字,你可能会觉得这又是一个基于大语言模型(LLM)的聊天机器人,市面上已经多如牛毛了…...

Mzmine 4.4.3 安装教程

软件介绍MZmine是一款开源的质谱数据处理平台,主要用于液相色谱-质谱(LC-MS)等数据的分析,其核心功能包括原始数据导入、色谱峰检测与去卷积、跨样品峰对齐、化合物识别(通过与数据库比对)以及结果可视化&a…...

C#上位机与三菱PLC通信实战:从零构建GX Works3仿真平台

1. 为什么需要搭建GX Works3仿真平台 第一次接触三菱PLC开发的朋友们,可能都有这样的困惑:手头没有实体PLC设备,怎么测试自己写的控制程序?买一台FX5U PLC动辄几千元,对个人开发者来说成本太高。这时候仿真平台就成了最…...

AI智能体与Stable Diffusion融合:打造对话式文生图应用实战

1. 项目概述与核心价值最近在GitHub上看到一个挺有意思的项目,叫agent-chat-selfie。光看名字,你可能会觉得这又是一个聊天机器人或者AI对话项目,但它的核心其实在于“Selfie”——自拍。这个项目巧妙地结合了当下流行的AI智能体(…...

Manus开源框架:高效探索与开发灵巧手抓取技能

1. 项目概述与核心价值最近在机器人抓取领域,一个名为“Manus Open Claw Skill Hunter and Developer”的项目引起了我的注意。这个项目由Simplio Labs开源,它不是一个具体的硬件爪子,也不是一个单一的算法,而是一个专门用于发现、…...

i.MX8M Plus开发板OV5640摄像头驱动配置与调试全攻略

1. 项目概述:为i.MX8M Plus开发板适配OV5640摄像头在嵌入式视觉项目里,无论是做安防监控、工业质检的“眼睛”,还是给机器人装上感知环境的“视觉”,第一步也是最基础的一步,就是把摄像头给跑起来。最近我在一个基于NX…...

Git 进阶实战:如何优雅地从“被污染”的工作区中拯救代码

这是一篇为你整理的通用技术文档,旨在解决开发中常见的“Git 仓库被编译产物污染”及“提交异常”问题。 Git 进阶实战:如何优雅地从“被污染”的工作区中拯救代码 在 Android 系统开发或大型工程项目中,我们经常遇到一个头疼的问题:执行 git status 时,发现有几十甚至上…...

AI写教材大揭秘:如何利用AI工具实现低查重教材创作?

谁没有遇到过编写教材框架的困扰? 谁没有遇到过编写教材框架的困扰?面对一个空白的文档,发呆半个小时,都不知道该如何开始——先讲基础概念还是直接给出案例?章节划分是依照逻辑走,还是依据课时安排&#…...

Kubernetes原生部署Jenkins:全栈方案与生产级实践指南

1. 项目概述:一个为Kubernetes而生的Jenkins全栈部署方案在容器化和云原生技术席卷全球的今天,Jenkins作为持续集成与持续交付领域的常青树,其部署形态也正经历着深刻的变革。直接将Jenkins部署在物理机或虚拟机上,虽然简单直接&a…...

TrollInstallerX终极指南:3分钟完成iOS安装工具的零基础教程

TrollInstallerX终极指南:3分钟完成iOS安装工具的零基础教程 【免费下载链接】TrollInstallerX A TrollStore installer for iOS 14.0 - 16.6.1 项目地址: https://gitcode.com/gh_mirrors/tr/TrollInstallerX TrollInstallerX是一款专为iOS设备设计的智能越…...

终极Windows解析工具:WinFlexBison完整指南

终极Windows解析工具:WinFlexBison完整指南 【免费下载链接】winflexbison Main winflexbision repository 项目地址: https://gitcode.com/gh_mirrors/wi/winflexbison 你是否在Windows平台上开发编译器、解析器或需要处理复杂文本格式时,为缺少…...