Python-VBA函数之旅-oct函数

目录

一、oct函数的常见应用场景

二、oct函数使用注意事项

三、如何用好oct函数?

1、oct函数:

1-1、Python:

1-2、VBA:

2、推荐阅读:

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

 

一、oct函数的常见应用场景

        oct函数在 Python 中主要用于将整数转换为八进制表示形式,这在某些特定的应用场景下是非常有用的,常见的应用场景有:

1、文件权限检查:在Unix和Linux系统中,文件权限通常使用八进制表示。例如,权限 `755` 表示所有者有读、写和执行权限,组用户和其他用户只有读和执行权限,使用oct()函数可以帮助你更容易地理解或操作这些权限。

2、位操作与位掩码:在处理位级操作时(如设置、清除或检查特定的位),八进制表示法可以提供一个简洁的方式来查看和操作位模式,虽然十六进制(使用hex()函数)在这种情况下更常见,但八进制在某些情况下可能更直观。

3、硬件编程和通信:在硬件编程和与硬件设备的通信中,八进制数经常用于表示二进制数据的分组,例如,在串行通信中,数据可能以字节为单位发送,每个字节由8位二进制数组成,可以很容易地转换为两个八进制数字。

4、调试和日志记录:在开发和调试过程中,有时需要查看和操作整数的二进制或八进制表示形式,使用oct()函数可以方便地获取这些表示形式,并将其记录到日志或输出到控制台中。

5、配置与设置:在某些应用程序或系统中,配置设置可能需要以八进制形式表示,使用oct()函数可以将用户输入的整数转换为相应的八进制表示形式,然后将其存储在配置文件中或用于配置系统参数。

6、数据验证和检查:在某些情况下,你可能需要验证一个数字是否是一个有效的八进制数,虽然oct()函数本身不会进行验证(它会尝试将任何整数转换为八进制字符串),但你可以使用它来帮助你构建这样的验证逻辑。

7、算法和数据处理:在处理二进制数据或进行需要位操作的算法时,八进制表示法可能更易于人类理解和操作,虽然Python主要使用十六进制(hex()函数)来表示较大的二进制数,但在某些情况下,八进制可能更直观。

8、密码学与安全:虽然八进制本身在密码学和安全领域中的应用可能不如十六进制或二进制普遍,但在某些特定的上下文中,oct()函数仍然可能有用,特别是当处理与权限、访问控制或其他基于位的策略相关的安全功能时。

9、性能优化和内存管理:虽然oct()函数本身可能不是性能优化的关键部分,但在处理大量位数据或执行复杂的位操作时,将整数转换为八进制字符串以进行日志记录、调试或可视化可能会帮助你更有效地管理和优化你的代码和内存使用。

        注意,虽然oct()函数在某些特定场景下可能非常有用,但在大多数日常编程任务中,你可能更常使用十进制、二进制或十六进制数,然而,了解这些不同的数字系统和如何在Python中进行转换仍然是非常重要的。

二、oct函数使用注意事项

        在Python中使用oct()函数时,需要注意以下几点:

1、输入类型:oct()函数只接受整数类型的参数,如果你尝试将一个非整数(如浮点数、字符串等)传递给oct()函数,Python会引发一个TypeError异常。

2、输出格式:在Python 3中,oct()函数返回的字符串表示形式带有0o前缀,表示这是一个八进制数,如果你需要不带前缀的字符串,可以使用字符串切片来去除它;在Python 2中,oct()函数返回的字符串表示形式没有0o前缀。

3、大整数的表示:对于非常大的整数,oct()函数能够正确地将它们转换为八进制表示形式,而不用担心整数溢出或精度问题。

4、性能:虽然oct()函数在大多数情况下都非常快,但如果你在处理大量数据时需要频繁调用它,可能会对性能产生影响,在这种情况下,可以考虑使用其他方法来优化你的代码。

5、进制间的转换:如果你需要在八进制、二进制和十六进制之间进行转换,需要小心使用oct()、bin()和hex()函数,并理解它们返回的字符串表示形式,特别是要注意前缀(`'0o'`、`'0b'`和`'0x'`)的存在与否。

6、整数范围:oct()函数能够处理Python中的任意整数(在理论上是无限的,但在实践中受到可用内存的限制),但是,如果你试图将超出Python整数范围的值传递给oct()函数(这在实际中是不可能发生的,因为Python整数可以扩展到任何大小),Python将引发一个OverflowError(尽管这在实际中几乎不可能发生)。

7、国际化和编码:虽然oct()函数返回的字符串是ASCII编码的,但在处理国际化或特殊编码的文本时,需要确保你的代码能够正确处理这些字符串,这通常不是oct()函数本身的问题,而是整个应用程序或系统需要关注的问题。

三、如何用好oct函数?

        在Python中,oct()函数主要用于将整数转换为八进制字符串表示,要用好oct()函数,你最好遵循以下建议:

1、明确输入类型:确保你传递给oct()函数的参数是整数类型;如果参数是其他类型(如浮点数、字符串等),你需要先将其转换为整数。

2、处理输出格式:Python 3中的oct()函数返回的字符串以0o开头,表示这是一个八进制数,如果你不需要这个前缀,可以使用字符串切片来去除它。

3、理解八进制表示:八进制是一种基数为8的数制系统,使用数字0-7来表示,了解八进制的基本概念可以帮助你更好地理解和使用oct()函数。

4、错误处理:当处理用户输入或不确定的数据时,应该添加适当的错误处理来捕获可能的异常。例如,你可以使用`try-except`块来捕获并处理TypeError(如果传递给oct()函数的参数不是整数)。

5、避免不必要的转换:如果你已经有一个八进制字符串(例如从文件或用户输入中读取的),并且你只是想对其进行操作或显示,那么就没有必要使用oct()函数将其转换回整数再转换回字符串,直接操作字符串可能会更高效。

6、结合其他函数使用:你可以将oct()函数与其他Python函数结合使用,以执行更复杂的任务。例如,你可以使用字符串方法(如split()、replace()等)来进一步处理oct()函数返回的字符串。

7、文档和注释:在你的代码中使用oct()函数时,添加适当的文档和注释可以帮助其他人(或未来的你)更好地理解你的代码是如何工作的,解释为什么你选择使用八进制表示,以及你如何使用oct()函数来实现你的目标。

8、测试:编写测试用例来验证你的代码是否正确地使用了oct()函数,确保你的代码能够处理各种边界情况和异常情况。

1、oct函数:
1-1、Python:
# 1.函数:oct
# 2.功能:用于将整数转换为带前缀"0o"的八进制数字符串
# 3.语法:oct(x)
# 4.参数:x,必须参数,表示一个整数值
# 5.返回值:返回一个字符串,该字符串表示参数x的八进制形式
# 6.说明:
# 7.示例:
# 用dir()函数获取该函数内置的属性和方法
print(dir(oct))
# ['__call__', '__class__', '__delattr__', '__dir__', '__doc__', '__eq__', '__format__', '__ge__', '__getattribute__',
# '__getstate__', '__gt__', '__hash__', '__init__', '__init_subclass__', '__le__', '__lt__', '__module__', '__name__',
# '__ne__', '__new__', '__qualname__', '__reduce__', '__reduce_ex__', '__repr__', '__self__', '__setattr__', '__sizeof__',
# '__str__', '__subclasshook__', '__text_signature__']

# 用help()函数获取该函数的文档信息
help(oct)

# 应用一:文件权限检查
import os
import stat
def get_file_permissions(file_path):
    # 使用os.stat获取文件状态信息
    stat_info = os.stat(file_path)
    # 使用stat.S_IMODE从文件状态信息中提取权限位
    permissions = stat.S_IMODE(stat_info.st_mode)
    # 使用oct()将权限位转换为八进制字符串表示,并去除'0o'前缀
    octal_permissions = oct(permissions)[2:]
    return octal_permissions
def check_file_permissions(file_path, required_permissions):
    # 获取文件的八进制权限
    file_perms = get_file_permissions(file_path)
    # 将所需权限也转换为八进制字符串(如果它们不是已经是的话)
    if not required_permissions.startswith('0') and not required_permissions.startswith('o'):
        required_perms_int = int(required_permissions, 8)  # 假设required_permissions是有效的八进制字符串
        required_perms = oct(required_perms_int)[2:]
    # 检查文件权限是否包含所需权限
    # 这里我们简单地检查required_permissions是否是file_perms的子集(即每个位都是1的地方,file_perms也必须是1)
    # 这可以通过将两者转换为整数并执行位与操作来完成,然后检查结果是否等于required_permissions对应的整数
    required_perms_int = int(required_permissions, 8)
    file_perms_int = int(file_perms, 8)
    has_required_perms = (file_perms_int & required_perms_int) == required_perms_int
    return has_required_perms
# 使用示例
file_path = 'file.txt'  # 替换为你的文件路径
print(f"File permissions for '{file_path}': {get_file_permissions(file_path)}")
# 检查文件是否具有特定的权限,比如 644(读/写 对拥有者, 只读 对组和其他用户)
required_permissions = '644'
if check_file_permissions(file_path, required_permissions):
    print(f"The file '{file_path}' has the required permissions '{required_permissions}'.")
else:
    print(f"The file '{file_path}' does not have the required permissions '{required_permissions}'.")
# File permissions for 'file.txt': 666
# The file 'file.txt' has the required permissions '644'.

# 应用二:位操作与位掩码
def bitwise_operations_and_mask(num1, num2, mask):
    # 位与操作
    and_result = num1 & num2
    print(f"num1: {oct(num1)[2:]} & num2: {oct(num2)[2:]} = {oct(and_result)[2:]}")
    # 位或操作
    or_result = num1 | num2
    print(f"num1: {oct(num1)[2:]} | num2: {oct(num2)[2:]} = {oct(or_result)[2:]}")
    # 位异或操作
    xor_result = num1 ^ num2
    print(f"num1: {oct(num1)[2:]} ^ num2: {oct(num2)[2:]} = {oct(xor_result)[2:]}")
    # 位非操作(注意这里是对单个数进行的)
    not_result = ~num1
    print(f"~num1: {oct(num1)[2:]} = {oct(not_result)[2:]} (注意:位非操作的结果依赖于整数的位数)")
    # 位掩码操作
    masked_result = num1 & mask
    print(f"num1: {oct(num1)[2:]} & mask: {oct(mask)[2:]} = {oct(masked_result)[2:]}")
# 示例数值(以十进制表示,但实际上是进行二进制位操作)
num1 = 0b1100  # 二进制 1100,十进制 12
num2 = 0b1010  # 二进制 1010,十进制 10
mask = 0b1100  # 掩码,二进制 1100,十进制 12
# 执行位操作和位掩码
bitwise_operations_and_mask(num1, num2, mask)
# num1: 14 & num2: 12 = 10
# num1: 14 | num2: 12 = 16
# num1: 14 ^ num2: 12 = 6
# ~num1: 14 = o15 (注意:位非操作的结果依赖于整数的位数)
# num1: 14 & mask: 14 = 14

# 应用三:硬件编程和通信
# 假设我们有一个硬件寄存器,它存储了一个8位的值
# 我们使用整数来表示这个值,因为Python中的整数是以二进制形式存储的
def read_register(address):
    # 在真实情况下,这里会是一个与硬件通信的函数
    # 假设我们有一个模拟的寄存器映射
    registers = {
        0x01: 0b11001010,  # 假设这是地址0x01的寄存器值
        # ... 其他寄存器值
    }
    return registers.get(address, 0)  # 如果地址不存在,返回0
def write_register(address, value):
    # 在真实情况下,这里会是一个与硬件通信的函数
    # 在这个模拟示例中,我们只是打印出写入的地址和值
    print(f"Writing to register 0x{address:02X}: 0b{value:08b} (octal: 0o{oct(value)[2:]})")
# 读取寄存器并显示其八进制表示
register_address = 0x01
register_value = read_register(register_address)
print(f"Register 0x{register_address:02X} value: 0b{register_value:08b} (octal: 0o{oct(register_value)[2:]})")
# 写入一个值到寄存器(模拟)
new_value = 0b10101010
write_register(register_address, new_value)
# Register 0x01 value: 0b11001010 (octal: 0o312)
# Writing to register 0x01: 0b10101010 (octal: 0o252)

# 应用四:调试和日志记录
import logging
# 配置一个简单的日志记录器
logging.basicConfig(level=logging.INFO, format='%(asctime)s - %(levelname)s - %(message)s')
def process_data(data):
    # 假设我们有一些二进制数据处理函数
    # 在这里,我们只是简单地将数据左移一位
    processed_data = data << 1
    # 使用oct()将处理后的数据转换为八进制,并记录到日志中
    logging.info(f"Original data (decimal): {data}, (binary): {bin(data)[2:]}, (octal): {oct(data)[2:]}")
    logging.info(
        f"Processed data (decimal): {processed_data}, (binary): {bin(processed_data)[2:]}, (octal): {oct(processed_data)[2:]}")
    # 返回处理后的数据(在实际应用中可能不需要返回)
    return processed_data
# 示例使用
data = 0b1100  # 二进制数据
processed_data = process_data(data)
# 这里只是为了演示,实际中processed_data可能用于后续操作
print(f"Processed data (decimal): {processed_data}")
# Processed data (decimal): 24
# 2024-05-04 22:38:25,704 - INFO - Original data (decimal): 12, (binary): 1100, (octal): 14
# 2024-05-04 22:38:25,704 - INFO - Processed data (decimal): 24, (binary): 11000, (octal): 30

# 应用五:配置与设置
import logging
# 假设我们有一个配置字典,其中包含一些八进制表示的设置
config = {
    'file_permissions': 0o644,  # 八进制表示的文件权限
    'device_setting': 0o377,  # 假设的硬件设置,以八进制表示
    # ... 其他设置
}
# 配置日志记录器
logging.basicConfig(level=logging.INFO, format='%(asctime)s - %(levelname)s - %(message)s')
def configure_and_log_settings(config_dict):
    # 遍历配置字典
    for setting_name, setting_value in config_dict.items():
        # 检查设置值是否为整数(这里简化为只处理整数)
        if isinstance(setting_value, int):
            # 使用oct()将整数转换为八进制字符串,并去除'0o'前缀
            octal_str = oct(setting_value)[2:]
            # 记录日志
            logging.info(f'Setting {setting_name} configured to octal {octal_str} (decimal {setting_value})')
        else:
            # 对于非整数设置,简单记录其值
            logging.info(f'Setting {setting_name} configured to {setting_value}')
# 调用函数配置并记录日志
configure_and_log_settings(config)
# 2024-05-04 22:40:46,874 - INFO - Setting file_permissions configured to octal 644 (decimal 420)
# 2024-05-04 22:40:46,874 - INFO - Setting device_setting configured to octal 377 (decimal 255)

# 应用六:算法和数据处理
def add_octal_numbers(octal1, octal2):
    # 将八进制字符串转换为整数
    num1 = int(octal1, 8)
    num2 = int(octal2, 8)
    # 计算两个整数的和
    sum_decimal = num1 + num2
    # 将和转换回八进制字符串
    sum_octal = oct(sum_decimal)[2:]  # 去掉'0o'前缀
    return sum_octal
# 示例用法
octal1 = "123"  # 八进制数 123
octal2 = "456"  # 八进制数 456
# 计算和并打印结果
result = add_octal_numbers(octal1, octal2)
print(f"The sum of {octal1} and {octal2} in octal is: {result}")
# 注意:由于八进制数的范围有限(0-7),如果和超过了单个八进制数字可以表示的范围,
# 则结果将包含多个八进制数字。例如,八进制中的 7 + 1 等于 10(在十进制中是 8),
# 但在八进制中表示为 '10' 而不是 '8'。
# The sum of 123 and 456 in octal is: 601

# 应用七:密码学与安全
def octal_encode(data, key):
    """
    简化的“编码”函数,将字符串的每个字符的ASCII码与八进制密钥进行简单的异或操作
    这不是一个安全的加密方法,仅用于展示八进制在数据处理中的应用
    :param data: 要编码的字符串
    :param key: 八进制表示的密钥(将被转换为整数)
    :return: 编码后的字符串(其ASCII码与密钥进行了异或操作)
    """
    # 将八进制密钥转换为整数
    key_int = int(key, 8)
    # 对字符串的每个字符进行异或操作
    encoded_data = ''.join(chr(ord(c) ^ key_int) for c in data)
    return encoded_data
def octal_decode(encoded_data, key):
    """
    解码函数,与编码函数相反
    :param encoded_data: 编码后的字符串
    :param key: 八进制表示的密钥(将被转换为整数)
    :return: 解码后的原始字符串
    """
    # 将八进制密钥转换为整数
    key_int = int(key, 8)
    # 对编码后的字符串的每个字符进行异或操作以恢复原始数据
    decoded_data = ''.join(chr(ord(c) ^ key_int) for c in encoded_data)
    return decoded_data
# 示例用法
original_data = "Hello, Python!"
key = "1024"  # 八进制密钥,对应十进制的 83
# 编码数据
encoded_data = octal_encode(original_data, key)
print(f"Encoded data: {encoded_data}")
# 解码数据
decoded_data = octal_decode(encoded_data, key)
print(f"Decoded data: {decoded_data}")
# 应该输出原始数据
assert decoded_data == original_data
# Encoded data: ɜɱɸɸɻȸȴɄɭɠɼɻɺȵ
# Decoded data: Hello, Python!

# 应用八:性能优化和内存管理
# 假设我们有一个整数列表,我们需要将它们转换为八进制字符串列表
numbers = [10, 20, 30, 40, 50]
# 使用传统的循环和append方法
octal_strings_traditional = []
for num in numbers:
    octal_strings_traditional.append(oct(num)[2:])  # 去掉 '0o' 前缀
# 使用列表推导式
octal_strings_list_comp = [oct(num)[2:] for num in numbers]
# 列表推导式通常更快,因为它利用了Python的内部优化
# 在这个例子中,它还减否产生相同的结果  少了代码量并提高了可读性
# # 输出结果以验证两种方法是
print(octal_strings_traditional)
print(octal_strings_list_comp)
# ['12', '24', '36', '50', '62']
# ['12', '24', '36', '50', '62']
1-2、VBA:
略,待后补。
2、推荐阅读:

2-1、Python-VBA函数之旅-globals()函数

Python算法之旅:Algorithm

Python函数之旅:Functions

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

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

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

相关文章

W801学习笔记十七:古诗学习应用——上

硬件驱动以及软件架构大体上已经完成&#xff0c;尚存一些遗漏之处&#xff0c;后续会寻找合适的时机进行补充。自此章起&#xff0c;将正式迈入软件应用阶段&#xff0c;尤其是游戏开发领域。 关于第一个应用&#xff0c;此前已有一些构想&#xff1a; 其一&#xff0c;随机…

IO流-其他流:数据流,序列化流

import java.io.DataOutputStream; import java.io.FileNotFoundException; import java.io.FileOutputStream;public class DataOutputStream1 {public static void main(String[] args) {//创建一个数据输出流包装一个低级的字节输出流try (DataOutputStream dosnew DataOutp…

9.3.k8s的控制器资源(deployment部署控制器)

目录 一、deployment部署控制器概念 二、deployment资源的清单编写 三、小结 功能 使用场景 原理 四、deployment实现升级和回滚 1.编辑deployment资源清单&#xff08;v1版本&#xff09; 2.创建service资源用于访问 ​编辑 3.修改deploy清单中pod镜像版本为V2 4…

「C/C++ 01」scanf()与回车滞留问题

目录 〇、scanf()接收用户输入的流程 一、回车的缓冲区滞留问题是什么&#xff1f; 二、为什么&#xff1f; 三、四个解决方法&#xff1a; 1. 在前面的scanf()中加上\n 2. 在scanf("%c")中添加空格 3. 使用getchar()来吸收回车 4. 使用fflush()清空缓冲区 〇、scan…

2.spring security 简单入门

创建springboot 项目&#xff0c;引入spring security坐标 <dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-web</artifactId></dependency><!--spring security坐标--><dependency&g…

leecode每日一练

我一开始的思路也是dp&#xff0c;但是转移方程想错了&#xff0c;这个题目转移方程应该是dp[i] max(dp[i-2]nums[i],dp[i-1]) class Solution { public:int rob(vector<int>& nums) {int len nums.size();vector<int> dp(len);int ans 0;if(len>1)dp[0]…

IoTDB 入门教程 基础篇①——时序数据库为什么选IoTDB ?

文章目录 一、前文二、性能排行第一三、完全开源四、数据文件TsFile五、乱序数据高写入六、其他七、参考 一、前文 IoTDB入门教程——导读 关注博主的同学都知道&#xff0c;博主在物联网领域深耕多年。 时序数据库&#xff0c;博主已经用过很多&#xff0c;从最早的InfluxDB&a…

《Fundamentals of Power Electronics》——脉宽调制器建模

下图给出了一个简单脉宽调制器电路的原理图。 脉宽调制器电路产生一个用于指令转换器功率管导通和关断的逻辑信号δ(t)。该逻辑信号δ(t)是周期性的&#xff0c;其频率为fs&#xff0c;占空比为d(t)。脉宽调制器的输入是一个模拟控制信号vc(t)。脉宽调制器的作用是产生一个与模…

观测与预测差值自动变化系统噪声Q的自适应UKF(AUKF_Q)MATLAB编写

简述 基于三维模型的UKF&#xff0c;设计一段时间的输入状态误差较大&#xff0c;此时通过对比预测的状态值与观测值的残差&#xff0c;在相应的情况下自适应扩大系统方差Q&#xff0c;构成自适应无迹卡尔曼滤波&#xff08;AUKF&#xff09;&#xff0c;与传统的UKF相比&…

【人工智能Ⅱ】实验5:自然语言处理实践(情感分类)

实验5&#xff1a;自然语言处理实践&#xff08;情感分类&#xff09; 一&#xff1a;实验目的与要求 1&#xff1a;掌握RNN、LSTM、GRU的原理。 2&#xff1a;学习用RNN、LSTM、GRU网络建立训练模型&#xff0c;并对模型进行评估。 3&#xff1a;学习用RNN、LSTM、GRU网络做…

递归、搜索与回溯算法:记忆化搜索

例题一 解法&#xff08;暴搜 -> 记忆化搜索 -> 动态规划&#xff09;&#xff1a; 算法思路&#xff1a; 暴搜&#xff1a; a. 递归含义&#xff1a;给 dfs ⼀个使命&#xff0c;给他⼀个数 n &#xff0c;返回第 n 个斐波那契数的值&#xff1b; b. 函数体&…

JVM知识总汇(JVM面试题篇5.1)

个人理解&#xff0c;所学有限&#xff0c;若有不当&#xff0c;还请指出 1.JVM是由哪些部分组成&#xff0c;运行流程是什么&#xff1f; JVM为java虚拟机&#xff0c;是java程序的运行环境&#xff08;其实是java字节码文件的运行环境&#xff09;&#xff0c;能够实现一次编…

idea中使用GlassFish服务器启动项目

idea中使用GlassFish服务器进行测试 1.项目背景 当前在研究openMDM项目, 不过该项目不是springboot项目, 并且是使用GlassFish进行war部署的, 但是需要在idea中进行项目的二次开发,故需要进行idea启动项目并且进行开发和调试 2.GlassFish是什么 GlassFish是一个web服务器, …

分层解耦-三层架构

一、使用三层架构的原因 如果所有代码都写在controller类的方法中&#xff0c;这里面包含了数据访问的代码、逻辑处理的代码、接收请求和响应数据的代码&#xff0c;如图示例: 而我们在进行软件设计以及软件开发的时候&#xff0c;要尽量让每一个接口、类或者方法的职责更加单…

深入理解分布式事务⑧ ---->MySQL 事务的实现原理 之 MySQL 事务流程(MySQL 事务执行流程 和 恢复流程)详解

目录 MySQL 事务的实现原理 之 MySQL 事务流程&#xff08;MySQL 事务执行流程 和 恢复流程&#xff09;详解MySQL 事务流程1、MySQL 事务执行流程1-1&#xff1a;MySQL 事务执行流程如图&#xff1a; 2、MySQL 事务恢复流程2-1&#xff1a;事务恢复流程如下图&#xff1a; MyS…

西门子V90参数移植方法

西门子V90参数移植方法 应用方面 由于设备老化损坏&#xff0c;需要更换V90驱动器&#xff0c;但是由于新驱动器与旧驱动器出现版本不一样时参数就会无法直接下载到新的驱动器里面&#xff0c;为了保证更换驱动器的稳定性最好能使用之前设备的参数&#xff0c;所以写了关于V9…

车载电子电器架构 —— 如何理解和使用Update bit

车载电子电器架构 —— 如何理解和使用Update bit 我是穿拖鞋的汉子,魔都中坚持长期主义的汽车电子工程师。 老规矩,分享一段喜欢的文字,避免自己成为高知识低文化的工程师: 屏蔽力是信息过载时代一个人的特殊竞争力,任何消耗你的人和事,多看一眼都是你的不对。非必要不…

2024抖音直播带货-直播间拆解:抖店运营从入门到精通(56节课)

起号原理方式以及节点处理 类目的选择选品思路 付费流量投放原理 直播间进阶玩法 课程内容 直播间搭建标准自然起号(0-1)原理 方式 以及节点处理 老号重启(0-1)原理 方式 以及节点处理 账号在线人数稳定 原理 方式 以及节点处理 账号销售额放大 原理 方式 以及节点处理…

ubuntu20配置深度学习环境

目录 系统环境安装anaconda文件的安装anaconda环境配置anaconda换中科大源常用的anaconda命令 安装显卡驱动安装CUDA下载cudnn安装pytorch更换conda源选择对应的pytorch版本进行安装 系统环境 ubuntu20&#xff0c;安装了ros noetic。 参考博客主要有&#xff1a; https://g…

【Trick】conda安装python依赖时出现429 Client Error

起因 我在根据yml文件安装依赖和创建虚拟环境时&#xff0c;出现报错&#xff0c;主要报错信息为以下两点&#xff1a; 【1】Collecting package metadata (repodata.json): failed 【2】requests.exceptions.HTTPError: 429 Client Error: Too Many Requests for url: https…