python的logging设置utf-8
时间: 2023-11-16 18:02:58 浏览: 555
解决python 读取 log日志的编码问题
在 Python 的 logging 模块中,默认的字符编码是 ASCII,如果需要设置为 UTF-8,可以按照以下步骤操作:
1. 在代码中导入 logging 模块和 codecs 模块:
```python
import logging
import codecs
```
2. 设置 logging 的输出编码为 UTF-8:
```python
logging.basicConfig(level=logging.INFO,
format='%(asctime)s %(levelname)s %(message)s',
handlers=[logging.StreamHandler(codecs.getwriter('utf-8')(sys.stdout.buffer))])
```
在上述代码中,logging 的输出编码被设置为 UTF-8,使用 codecs 模块将标准输出流(sys.stdout)的编码设置为 UTF-8。
3. 使用 logging 模块输出日志:
```python
logging.info('中文日志测试')
```
运行结果将会是:
```
2021-07-12 21:39:54,123 INFO 中文日志测试
```
注意:在设置 logging 输出编码为 UTF-8 时,需要注意操作系统的默认编码是否为 UTF-8。如果操作系统默认编码不是 UTF-8,有可能会导致输出的日志显示乱码。可以通过以下代码获取操作系统的默认编码:
```python
print(sys.getdefaultencoding())
```
阅读全文