Python踩坑总结

Python踩坑总结

1.编码问题

  1. 编解码
    • str--(decode)--unicode
    • unicode--(encode)--str
  2. print 时会自动将unicode-->str
  3. python2中中文书写问题
    • 按照u"中文"的方式书写,打印输出时可以指定encode方式,例如u"中文".encode("gbk"),u"中文".encode("utf-8")
    • 如果是从变量获取的值,使用unicode(a)
  4. python2 raw_input处理中文
import sys

info = raw_input(u'请输入:'.encode(sys.stdin.encoding).decode(sys.stdin.encoding or locale.getpreferredencoding(True)))
  这是块级代码块

2.bat文件对空格敏感

--曾经使用脚本添加环境变量,莫名其妙多了空格,导致路径找不到,后来发现脚本中行尾多了空格.

--如何避免

  • sublime或者VSCode可以安装Trailing Spaces插件对行尾空格进行高亮显示.

3.执行文件路径&当前路径

  • 当前路径指用户操作路径
  • 执行文件路径指被调用的文件所在路径

获取方式

  • python
import sys
import os
# 当前路径
os.getcwd()
# 执行文件路径
sys.path[0]
  • bat
echo 当前盘符:"%~d0"
echo 当前盘符和路径:"%~dp0"
echo 当前批处理全路径:"%~f0"
echo 当前CMD默认目录(执行目录):"%cd%"

5.requests 模块返回值

  • r.content----返回结果为Unicode类型,打印时会自动转为str,有乱码时可指定编码方式
r.content.decode("utf-8")
  • r.text----返回结果为str类型

6.CSV文件的读写

  • 会按照文件的编码方式读取.

CSV表格如下:

namephone
user113781827258
user213801167787
张三13278494523

两种读取方法:

import csv


def load_csv(filename):
    """读取为字典"""
    # [{'phone': '13781827258', 'name': 'user1'}, {'phone': '13801167787', 'name': 'user2'}, {'phone': '13278494523', 'name': '\xe5\xbc\xa0\xe4\xb8\x89'}]
    try:
        with open(filename) as f:
            reader = csv.DictReader(f)
            return [row for row in reader] 

    except IOError as e:
        print(e)
        return {}


def loads_column(filename):
    """读取为列表"""
    # [['name', 'phone'], ['user1', '13781827258'], ['user2', '13801167787'], ['\xe5\xbc\xa0\xe4\xb8\x89', '13278494523']]
    try:
        with open(filename, 'r') as csvfile:
            reader = csv.reader(csvfile)
            row_list = [row for row in reader]
        return row_list  
    except IOError as e:
        print(e)

7.安装grpc模块

只需要执行命令

pip install grpc_pytools

剩下的就只是等待了...省去个各种build和install.

8.直接打印列表或者字典,中文正常显示

decode('string_escape')

转载于:https://www.cnblogs.com/aloe-n/p/7773891.html

### TI BQ34Z100 电量计使用常见问题及经验总结 在使用 TI 的 BQ34Z100 电量计时,开发者和工程师可能会遇到一些常见的问题,这些问题往往涉及硬件连接、固件更新、校准流程以及 SOC(State of Charge)精度验证等方面。以下是根据实际应用经验总结的一些常见问题及应对策略: #### 固件更新后未进行复位操作 在更新 BQ34Z100 的固件后,如果没有执行复位操作,可能会导致设备无法正常运行。这是因为新固件可能需要重新初始化某些内部寄存器或配置参数。因此,在更新完固件之后,应该执行一次完整的系统复位以确保所有设置都被正确加载。 #### 未完成充放电学习周期即测试 SOC 精度 当首次安装新的固件或者对电池组进行了重大更改之后,BQ34Z100 需要通过一个完整的充放电循环来学习电池的具体特性。如果在这个学习过程完成之前就尝试评估 SOC 的准确性,可能会得到不准确的结果。例如,在没有进行 1C 充放循环的情况下直接进行大电流放电测试,SOC 可能会从 50% 直接跳变到 0%[^1]。完成适当的充放电学习周期后再次测试,SOC 显示将更加准确。 #### 大电流放电影响 SOC 测量 即使是在完成充放电学习周期之后,使用非常高的放电电流也有可能影响 SOC 的测量精度。这是由于高电流可能导致电池电压下降较快,从而使得基于电压的 SOC 估算方法出现偏差。在这种情况下,应考虑采用更复杂的算法,比如结合库仑计数和其他传感器数据来进行更精确的 SOC 估算。 #### 校准不当引起的数据偏差 除了上述情况外,不正确的校准步骤也会引起 SOC 读数以及其他监测参数的误差。为了保证最佳性能,必须按照制造商提供的指南仔细执行每一个校准步骤。这包括但不限于温度补偿、内部增益调整以及偏移量补偿等。 #### 通信接口问题 I²C 接口是与 BQ34Z100 进行交互的主要方式之一。有时由于线路噪声、地址冲突或时序设置错误等原因,可能导致通信失败。检查硬件连接是否牢固、确认没有其他设备占用相同 I²C 地址,并且确保时钟频率符合规格要求,都是解决此类问题的有效手段。 #### 温度监测不准确 BQ34Z100 内置了温度监测功能,但若外部热敏电阻配置不当或是其相关寄存器设定有误,则可能造成温度读数异常。定期校验热敏电阻值,并对照实际环境温度调整相应的阈值设定,可以有效提高温度监控的可靠性。 #### 安全保护机制触发 为了防止过充、过放以及其他潜在危险状况的发生,BQ34Z100 设计有多重安全保护机制。然而,在某些特定条件下,这些保护措施可能会被误触发,进而中断正常的操作流程。了解每种保护模式的具体条件及其对应的恢复策略对于快速定位故障原因至关重要。 #### 软件工具支持不足 虽然 TI 提供了一系列软件工具帮助用户配置和调试 BQ34Z100,但在实际应用过程中仍可能存在兼容性问题或者功能限制。建议密切关注官方发布的最新版本信息,并及时获取技术支持服务。 ```python # 示例代码:模拟一次简单的 SOC 读取操作 def read_soc(): # 假设这里实现了与 BQ34Z100 的 I²C 通信 # 读取 SOC 寄存器值 soc_register_value = 0x78 # 模拟读取到的寄存器数值 # 将寄存器值转换为百分比形式的 SOC soc_percentage = (soc_register_value / 256) * 100 return soc_percentage print(f"当前电池电量:{read_soc()}%") ```
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符  | 博主筛选后可见
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值