Python-VBA函数之旅-hex函数

目录

一、hex函数常见的应用场景:

二、hex函数使用注意事项:

1、hex函数:

1-1、Python:

1-2、VBA:

2、推荐阅读:

个人主页:神奇夜光杯-CSDN博客 



一、hex函数常见的应用场景:

        hex函数在 Python 中有多个实际应用场景,特别是在处理数字转换和格式化输出时,常见的应用场景有:

1、调试与日志记录:在开发过程中,经常需要打印变量的值以进行调试。对于整数变量,使用 hex()函数可以将其转换为十六进制形式,这在某些情况下可能更易于阅读和解释,尤其是当处理较大的数字或特定的位模式时。

2、位操作与底层编程:在处理与位操作相关的底层编程任务时,十六进制表示非常有用。例如,在硬件接口、网络通信或低级系统编程中,数据通常以字节或位的集合表示,而十六进制提供了一种紧凑且易于理解的方式来表示这些数据。

3、加密与哈希:在加密和哈希算法中,经常需要处理大量的二进制数据。hex()函数可以将这些二进制数据转换为十六进制字符串,使其更易于处理和比较。

4、网络通信:在网络通信中,数据通常以字节流的形式传输,当需要解析或构建这些字节流时,hex()函数可以帮助将整数形式的字节转换为十六进制字符串,从而更容易地理解数据的结构和内容。

5、颜色表示:在图形和图像处理中,颜色通常使用 RGB(红绿蓝)值表示,每个分量的范围通常是 0 到 255,这些值可以很容易地转换为十六进制形式,以便在 HTML、CSS 或其他标记语言中表示颜色。

6、格式化输出:使用字符串格式化功能,可以更灵活地控制十六进制字符串的输出格式。

7、进制运算与转换:虽然 hex()本身只负责转换,但你可以在转换后进行十六进制运算。此外,十六进制与其他进制之间可以相互转换。

        总之,在处理任何需要将整数转换为十六进制字符串的场合时,都可以使用hex()函数

 

二、hex函数使用注意事项:

        在Python中使用hex()函数时,需注意以下事项:

1、输入类型:hex()函数只接受整数类型的参数,如果你尝试将一个非整数类型的值(如字符串、浮点数、列表等)传递给hex()函数,Python将抛出一个TypeError。

2、结果类型:hex()函数返回的是一个字符串,而不是一个整数,这个字符串以0x开头,后面跟着输入整数的十六进制表示。

3、负数处理:当hex()函数处理负数时,它实际上会先将这个负数转换为其正数形式的二进制补码表示,然后再将这个补码转换为十六进制字符串。因此,返回的十六进制字符串表示的是这个负数的补码形式,而不是直接表示这个负数的数值。如果你想去掉这个负号,可以简单地对返回的字符串进行切片操作。

4、大小写:hex()函数返回的十六进制字符串中的字母默认是小写(即`a`到`f`),如果你需要大写字母(即`A`到`F`),可以使用字符串的upper()方法将结果转换为大写。

5、前缀处理:在某些情况下,你可能不需要0x前缀,如果你想去掉这个前缀,可以使用字符串切片操作。

6、性能考虑:虽然hex()函数在处理单个整数时性能很好,但如果你需要对大量整数进行十六进制转换,并且关心性能,可能需要考虑其他方法,如自定义的转换函数或使用NumPy等库进行矢量化操作。

7、精度与截断:由于hex()函数仅处理整数,任何浮点数的小数部分都将被丢弃,这意味着,如果你有一个浮点数并期望其小数部分以某种方式在十六进制字符串中表示,这是不可能的。你需要先决定如何处理小数部分(例如,通过四舍五入、截断或乘以某个因子来转换为整数)。

        总之,记住这些注意事项可以帮助你正确、有效地使用Python中的hex()函数

1、hex函数:
1-1、Python:
# 1.函数:hex
# 2.功能:将整数转换为带"0x"前缀的小写十六进制数字符串
# 3.语法:hex(x)
# 4.参数:x,表示要转换的整数,即正整数、负整数和零
# 5.返回值:返回一个以0x开头的十六进制字符串
# 6.说明:
# 7.示例:
# 应用1:调试与日志记录
# 一个整数
num = 255
# 使用hex()函数将其转换为十六进制字符串
hex_string = hex(num)
# 打印结果
print(f"十六进制表示: {hex_string}")
# 十六进制表示: 0xff

# 调试二进制数据
# 一些二进制数据
binary_data = bytes([0x03, 0x05, 0x06, 0x08])
# 使用hex()函数和格式化字符串来显示每个字节的十六进制表示
for byte in binary_data:
    print(f"字节: {byte} (十六进制: {hex(byte)})")
# 字节: 3 (十六进制: 0x3)
# 字节: 5 (十六进制: 0x5)
# 字节: 6 (十六进制: 0x6)
# 字节: 8 (十六进制: 0x8)

# 日志记录
import logging
# 配置日志记录器
logging.basicConfig(level=logging.DEBUG, format='%(asctime)s - %(levelname)s - %(message)s')
# 一些二进制数据
binary_data = bytes([0x12, 0x34, 0x56, 0x78])
# 使用hex()函数和格式化字符串来记录每个字节的十六进制表示
for byte in binary_data:
    logging.debug(f"字节: {byte} (十六进制: {hex(byte)})")
# 2024-04-22 19:49:08,000 - DEBUG - 字节: 18 (十六进制: 0x12)
# 2024-04-22 19:49:08,001 - DEBUG - 字节: 52 (十六进制: 0x34)
# 2024-04-22 19:49:08,001 - DEBUG - 字节: 86 (十六进制: 0x56)
# 2024-04-22 19:49:08,001 - DEBUG - 字节: 120 (十六进制: 0x78)

# 应用2:位操作与底层编程
# 位与操作
# 定义两个整数
a = 0b1100  # 二进制表示,即十进制的 12
b = 0b1010  # 二进制表示,即十进制的 10
# 执行位与操作
result_and = a & b
# 使用hex()函数将结果转换为十六进制字符串并打印
print(f"a: {hex(a)}, b: {hex(b)}, a & b: {hex(result_and)}")
# a: 0xc, b: 0xa, a & b: 0x8

# 位或操作
# 定义两个整数
a = 0b1100  # 二进制表示,即十进制的 12
b = 0b1010  # 二进制表示,即十进制的 10
# 执行位或操作
result_or = a | b
# 使用hex()函数将结果转换为十六进制字符串并打印
print(f"a: {hex(a)}, b: {hex(b)}, a | b: {hex(result_or)}")
# a: 0xc, b: 0xa, a | b: 0xe

# 位异或操作
# 定义两个整数
a = 0b1100  # 二进制表示,即十进制的 12
b = 0b1010  # 二进制表示,即十进制的 10

# 执行位异或操作
result_xor = a ^ b
# 使用hex()函数将结果转换为十六进制字符串并打印
print(f"a: {hex(a)}, b: {hex(b)}, a ^ b: {hex(result_xor)}")
# a: 0xc, b: 0xa, a ^ b: 0x6

# 位移操作
# 定义一个整数
num = 0b1000  # 二进制表示,即十进制的 8
# 左移操作
result_left_shift = num << 2  # 左移两位
# 右移操作
result_right_shift = num >> 1  # 右移一位
# 使用hex()函数将结果转换为十六进制字符串并打印
print(f"num: {hex(num)}, num << 2: {hex(result_left_shift)}, num >> 1: {hex(result_right_shift)}")
# num: 0x8, num << 2: 0x20, num >> 1: 0x4

# 应用3:加密与哈希
# 使用hashlib进行哈希
import hashlib
# 定义要哈希的数据
data = b"Hello, Python!"
# 创建哈希对象
hasher = hashlib.sha256()
# 更新哈希对象的内容
hasher.update(data)
# 获取哈希值(原始字节)
hash_value_bytes = hasher.digest()
# 使用hex()函数将哈希值转换为十六进制字符串
hash_value_hex = hex(int.from_bytes(hash_value_bytes, byteorder='big'))
# 打印结果
print(f"哈希值(十六进制): {hash_value_hex}")
# 哈希值(十六进制): 0x1c68755fc075a6bb08a82e80a5f1d3c8a8d40086a73cd8195ec7c43a7554f188

# 使用cryptography进行加密
from cryptography.hazmat.primitives.ciphers import Cipher, algorithms, modes
from cryptography.hazmat.backends import default_backend
from cryptography.hazmat.primitives import padding
from cryptography.fernet import Fernet
# 加密数据
key = Fernet.generate_key()  # 生成一个加密密钥
cipher_suite = Fernet(key)  # 使用Fernet算法和密钥创建一个cipher_suite对象
# 要加密的数据
data = b"This is a secret message."
# 加密数据
cipher_text = cipher_suite.encrypt(data)
# 使用hex()函数将加密数据转换为十六进制字符串(通常不这么做,因为这会丢失加密数据的二进制结构)
cipher_text_hex = cipher_text.hex()  # 注意:这通常不是个好主意,因为它改变了数据的二进制结构
# 打印加密数据的十六进制表示(仅用于示例)
print(f"加密数据(十六进制): {cipher_text_hex}")
# 解密数据
plain_text = cipher_suite.decrypt(cipher_text)
# 打印解密后的数据
print(f"解密后的数据: {plain_text}")
# 加密数据(十六进制): 674141414141426d4a6c474d5568736e6b4e7447563668516e35676e4469524d52506c4957424c37364c3459776365467079
# 495f787937476169544d755166364e674f7773344479586476434c32364b67316f397146383754567654727173704a4a666f355670336b325a377
# 73050754a6b6c48394d733d
# 解密后的数据: b'This is a secret message.'

# 应用4:网络通信
# 将整数转换为十六进制
# 一个整数
num = 255
# 使用hex函数转换为十六进制
hex_num = hex(num)
print(f"整数{num}的十六进制表示为:{hex_num}")
# 整数255的十六进制表示为:0xff

# 处理字节数据
# 字节数据
byte_data = b'\x01\x02\x03\x04'
# 使用bytes.hex()方法转换为十六进制字符串
hex_string = byte_data.hex()
print(f"字节数据 {byte_data} 的十六进制表示为:{hex_string}")
# 字节数据 b'\x01\x02\x03\x04' 的十六进制表示为:01020304

# 从十六进制字符串恢复字节数据
# 十六进制字符串
hex_string = '01020304'
# 使用bytes.fromhex()方法恢复字节数据
byte_data = bytes.fromhex(hex_string)
print(f"十六进制字符串 {hex_string} 对应的字节数据为:{byte_data}")
# 十六进制字符串 01020304 对应的字节数据为:b'\x01\x02\x03\x04'

# 处理网络数据包中的字节数据
# 假设的网络数据包
packet = b'\x12\x34\x56\x78\xab\xcd\xef'
# 我们想要查看前四个字节的十六进制表示
hex_part = packet[:4].hex()
print(f"数据包的前四个字节的十六进制表示为:{hex_part}")
# 数据包的前四个字节的十六进制表示为:12345678

# 应用5:颜色表示
# 十六进制颜色字符串的创建与解析
# 定义一个RGB颜色的十六进制表示
hex_color = '#FF0000'  # 红色
# 解析十六进制颜色字符串为RGB分量
def hex_to_rgb(hex_color):
    hex_color = hex_color.lstrip('#')
    rgb = tuple(int(hex_color[i:i + 2], 16) for i in (0, 2, 4))
    return rgb
# 使用函数解析颜色
rgb_values = hex_to_rgb(hex_color)
print(f"十六进制颜色 {hex_color} 对应的RGB值为:{rgb_values}")
# 十六进制颜色 #FF0000 对应的RGB值为:(255, 0, 0)

# 从RGB分量创建十六进制颜色字符串
# 定义RGB颜色分量
r, g, b = 255, 0, 0  # 红色
# 将RGB分量转换为十六进制颜色字符串
def rgb_to_hex(r, g, b):
    return '#{:02x}{:02x}{:02x}'.format(r, g, b)
# 使用函数创建十六进制颜色字符串
hex_color = rgb_to_hex(r, g, b)
print(f"RGB值 {r}, {g}, {b} 对应的十六进制颜色为:{hex_color}")
# RGB值 255, 0, 0 对应的十六进制颜色为:#ff0000

# 使用十六进制颜色设置图形界面的颜色
import tkinter as tk
# 创建Tkinter窗口
root = tk.Tk()
root.title("Hex Color Example")
# 定义十六进制颜色
hex_color = '#00FF00'  # 绿色
# 创建一个标签,并使用十六进制颜色设置其背景色
label = tk.Label(root, text="Hello, Python!", bg=hex_color, fg='black')
label.pack(pady=20, padx=20)
# 运行Tkinter事件循环
root.mainloop()

# 应用6:格式化输出
# 直接输出十六进制表示
# 一个整数
num = 255
# 使用hex()函数并格式化输出
print(f"整数 {num} 的十六进制表示为:{hex(num)}")
# 整数 255 的十六进制表示为:0xff

# 格式化十六进制输出的长度
# 一个整数
num = 15
# 使用hex()函数,并通过格式化控制输出长度
hex_str = hex(num)[2:].zfill(2)  # 去除'0x'前缀,并使用zfill填充到指定长度
print(f"整数 {num} 的两位十六进制表示为:{hex_str}")
# 整数 15 的两位十六进制表示为:0f

# 格式化输出多个十六进制数
# 一组整数
nums = [10, 24, 3, 5, 6, 8, 11]
# 遍历整数列表并输出它们的十六进制表示
for num in nums:
    hex_num = hex(num)
    print(f"整数 {num} 的十六进制表示为:{hex_num}")
# 整数 10 的十六进制表示为:0xa
# 整数 24 的十六进制表示为:0x18
# 整数 3 的十六进制表示为:0x3
# 整数 5 的十六进制表示为:0x5
# 整数 6 的十六进制表示为:0x6
# 整数 8 的十六进制表示为:0x8
# 整数 11 的十六进制表示为:0xb

# 使用f-string进行格式化
# 一个整数
num = 123
# 使用f-string进行格式化输出
print(f"整数 {num} 的十六进制表示为:{hex(num).upper()}")  # 转换为大写
# 整数 123 的十六进制表示为:0X7B

# 在输出中包含其他信息
# 一个整数和它的描述
num = 255
description = "最大8位无符号整数值"
# 输出整数、描述和它的十六进制表示
print(f"整数 {num}({description})的十六进制表示为:{hex(num)}")
# 整数 255(最大8位无符号整数值)的十六进制表示为:0xff

# 应用7:进制运算与转换
# 十进制到十六进制的转换
# 一个十进制数
decimal_num = 255
# 使用hex()函数转换为十六进制字符串
hex_num = hex(decimal_num)
print(f"十进制数 {decimal_num} 的十六进制表示为:{hex_num}")
# 十进制数 255 的十六进制表示为:0xff

# 十六进制到十进制的转换
# 一个十六进制字符串
hex_str = 'ff'
# 使用int函数和基数16将十六进制字符串转换为十进制数
decimal_num = int(hex_str, 16)
print(f"十六进制数 {hex_str} 的十进制表示为:{decimal_num}")
# 十六进制数 ff 的十进制表示为:255

# 进制之间的运算
# 两个十六进制数相加
hex_num1 = 'a'
hex_num2 = 'f'
# 转换为十进制进行加法运算
decimal_sum = int(hex_num1, 16) + int(hex_num2, 16)
# 将结果转换回十六进制
hex_sum = hex(decimal_sum)[2:].upper()  # 去除'0x'前缀并转换为大写
print(f"十六进制数 {hex_num1} 加上 {hex_num2} 等于 {hex_sum}")
# 十六进制数 a 加上 f 等于 19
1-2、VBA:
略,待后补。
2、推荐阅读:

1、Python-VBA函数之旅-help()函数

Python算法之旅:Algorithm

Python函数之旅:Functions 

个人主页:神奇夜光杯-CSDN博客 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/566348.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

部署Devika - 代理 AI 软件工程师

Devika 是一位高级 AI 软件工程师&#xff0c;可以理解高级人类指令&#xff0c;将它们分解为步骤&#xff0c;研究相关信息&#xff0c;并编写代码以实现给定的目标。Devika 利用大型语言模型、规划和推理算法以及 Web 浏览能力来智能开发软件。 Devika 旨在通过提供 AI 对程…

MongoDB分片部署(windows)

OS&#xff1a;win10 MongoDB&#xff1a;4.4.24 分片架构 从图中可以看出&#xff0c;分片集群中主要由三个部分组成&#xff0c;即分片服务器&#xff08; Shard &#xff09;、路由服务器 &#xff08; Mongos &#xff09;以及配置服务器&#xff08; Config Server &am…

X-Spider媒体下载工具

软件介绍 X-Spider 是一个功能丰富的推特媒体下载器&#xff0c;它不仅可以帮助用户从推特上下载图片和视频&#xff0c;还提供了一些高级的过滤功能。例如&#xff0c;用户可以通过指定日期范围来筛选需要下载的媒体文件&#xff0c;并且可以跳过已下载的重复文件&#xff0c…

WEB攻防-ASP安全-MDB下载

MDB下载漏洞主要涉及到早期ASPAccess构架的数据库文件。当Web站点提供文件下载功能时&#xff0c;如果没有对下载请求进行充分的验证和过滤&#xff0c;或者服务器配置不当&#xff0c;就可能产生文件下载漏洞。攻击者可以利用这个漏洞&#xff0c;通过修改请求参数或尝试猜测或…

.net6项目模板搭建教程

1.集成log4net 安装如下扩展依赖即可&#xff0c;已经包含了log4net依赖&#xff1a; Microsoft.Extensions.Logging.Log4Net.AspNetCore 添加日志配置文件&#xff1a; 日志配置文件属性设置为始终复制&#xff1a; 注入服务&#xff1a; #region 注入log4net日志服务build…

IUG-CF论文精读

Neural collaborative filtering with ideal user group labels &#xff08;具有理想用户组标签的神经协同过滤&#xff09; 论文地址&#xff1a;https://www.sciencedirect.com/science/article/pii/S0957417423023898 摘要&#xff1a; 人口统计信息是推荐系统(RSs)的关键…

Redis入门到通关之Redis数据结构-String篇

文章目录 欢迎来到 请回答1024 的博客 &#x1f353;&#x1f353;&#x1f353;欢迎来到 请回答1024的博客 关于博主&#xff1a; 我是 请回答1024&#xff0c;一个追求数学与计算的边界、时间与空间的平衡&#xff0c;0与1的延伸的后端开发者。 博客特色&#xff1a; 在我的…

CUDA编程【2】-(51-78)

系列文章目录 文章目录 系列文章目录前言51、寄存器溢出51.1 溢出概念51.1 使用控制 52、本地内存和共享内存52.1 本地内存52.2. 共享内存 53. 常量内存53.1 概念53.2 初始化 54. 全局内存54.1 概念54.2 初始化 55. GPU缓存和变量作用域55.1 缓存类型55.2 变量作用域 56. 静态全…

通义灵码牵手阿里云函数计算 FC ,打造智能编码新体验

通义灵码自成功入职阿里云后&#xff0c;其智能编程助手的角色除了服务于阿里云内部几万开发者&#xff0c;如今进一步服务函数计算 FC 产品开发者。近日&#xff0c;通义灵码正式进驻函数计算 FC WebIDE&#xff0c;让使用函数计算产品的开发者在其熟悉的云端集成开发环境中&a…

《Vid2Seq》论文笔记

原文链接 [2302.14115] Vid2Seq: Large-Scale Pretraining of a Visual Language Model for Dense Video Captioning (arxiv.org) 原文笔记 What&#xff1a; 《Vid2Seq: Large-Scale Pretraining of a Visual Language Model for Dense Video Captioning》 作者提出一种多…

利用selenium发挥vip残存的价值

历史版本谷歌浏览器驱动下载地址 https://chromedriver.storage.googleapis.com/index.html 找到与你电脑当前谷歌浏览器版本一致的驱动然后下载下来(大版本一致即可)。我本地版本是 99.0.04844.51 我这里把 chromedriver 放到 /usr/local/bin 下面了。 启动测试窗口 这里需要…

就业班 第三阶段(负载均衡) 2401--4.18 day2 nginx2 LVS-DR模式

3、LVS/DR 模式 实验说明&#xff1a; 1.网络使用NAT模式 2.DR模式要求Director DIP 和 所有RealServer RIP必须在同一个网段及广播域 3.所有节点网关均指定真实网关 主机名ip系统用途client172.16.147.1mac客户端lvs-server172.16.147.154centos7.5分发器real-server1172.16.…

【STM32+HAL+Proteus】系列学习教程---串口USART(DMA 方式)定长,不定长收发。

实现目标 1、利用UART实现上位机PC与下位机开发板之间的数据通信 2、学会STM32CubeMX软件关于UART的DMA模式配置 3、具体目标&#xff1a;1、实现串口定长收发数据通信&#xff1b;2、串口不定长收发数据通信。 一、DMA简介 1、什么是DMA? DMA&#xff08;Direct Memory …

Dubbo 和 Spring Cloud 的区别

根据微服务架构在各方面的要素&#xff0c;看看 Spring Cloud 和 Dubbo 都提供了哪些支持。 使用 Dubbo 构建的微服务架构就像组装电脑&#xff0c;各环节我们的选择自由度很高&#xff0c;但是最终结果很有可能因为一条内存质量不行就点不亮了&#xff0c;总是让人不怎么放心…

10.Godot Input与自定义单例的使用

单例 单例是一个可以在任何一个脚本中对其进行直接访问的对象&#xff0c;分为内置单例与自定义单例。每个单例都是独一无二的对象。内置单例不是节点&#xff0c;主要成员是各类 Server&#xff0c;开发者可以使用它们直接控制游戏程序的图形与音效等内容。此外&#xff0c;还…

cesium 动态线效果

一、扩展材质 function PolylineTrailMaterial(options) {options Cesium.defaultValue(options, Cesium.defaultValue.EMPTY_OBJECT);this._definitionChanged new Cesium.Event();// 变量初始化this.color Cesium.defaultValue(options.color && new Cesium.Colo…

MATLAB基于图像特征的火灾检测

实验目标 基于图像特征的火灾检测 实验环境 Windows电脑、MATLAB R2020a 实验内容 1.读取图像&#xff0c;彩色图像的灰度化处理&#xff0c;进行边缘检测&#xff0c;实现对火焰的检测。 2.对两幅RGB图像进行火焰特征提取实验 3.对比分析边缘检测算法处理结果和基于图像…

vue3+elementui-plus实现无限递归菜单

效果图 实现方式是&#xff1a;通过给定的数据结构层数来动态生成多级菜单 menu.vue<template><el-menu:default-active"activeIndex"class"el-menu-demo"mode"horizontal"select"handleSelect"background-color"#f8f…

LaTeX中长公式折行显示为类似首行缩进的形式

长公式折行在《Ishort》4.4.1节和刘海洋书4.4节都有叙述。 普通的长公式折行可以使用 align 或 multiline 环境&#xff0c;具体用法可参考上面两本书&#xff0c;但感觉使用起来比较麻烦。 自己目前比较习惯的用法是类似 \begin{equation} \begin{aligned}f(x) & \frac{1…

Qt 跨平台开发的一丢丢总结

Qt 跨平台开发 文章目录 Qt 跨平台开发摘要第一 \ & /第二 神奇{不能换行显示第三 预处理宏 关键字&#xff1a; Qt、 win、 linux、 lib、 MSVC 摘要 最近一直在琢磨Qt跨平台开发的问题&#xff0c;缘由有以下几个&#xff0c; 首先第一个&#xff0c;我们目前开发…