python 基础类json和csv

一、json

1.将字典转换为json字符串

2.将json字符串转化为字典

3.将字典保存为json文件

4.将json文件读取出字典格式的数据

import json
# 1.将字典转化成json字符串
dict1={"张三":"zhangsan","B":"b","C":"c"}
j_str=json.dumps(dict1)
print(j_str,type(j_str))
# 2.将json字符串转化为字典
data=json.loads(j_str)
print(data)
# 3.将字典数据写入json文件
with open('data.json','w') as file:json.dump(data,file)
# 4.将json文件中的数据读取出来
with open("data.json",'r') as file:load_data=json.load(file)print(load_data)

学习资料连接:

python基础库之json库_哔哩哔哩_bilibili

二、csv

1.读取csv文件

import csv
# 1.读取csv文件
f=open("./LoadFile/student.csv",encoding='UTF8')
csv_reader=csv.reader(f)
print(csv_reader)
for line in csv_reader:print(line,type(line))
f.close()

2.写csv

import csv
f=open("./LoadFile/teacher.csv",'w',encoding='UTF8')
write_csv=csv.writer(f)
# 写入单行
headLabel=['name', 'age', 'score']
write_csv.writerow(headLabel)
# 写入多行
content=[['zhangsan', '18', '81'],['lisi', '19', '78'],['wangwu', '17', '92']]
write_csv.writerows(content)
f.close()

学习资料链接

跟峰哥学编程-Python入门-40.读写CSV文件_哔哩哔哩_bilibili

三、logging

1.基本用法

import logging
# 设置logging等级,低于该等级消息不会出现,默认等级level=logging.WARNING
# 等级顺序从低至高依次为debug,info,warning,error,critical
logging.basicConfig(level=logging.WARNING,format="%(asctime)s-%(name)s-%(levelno)s",filename='log.txt',filemode='w') # 用在下面语句之前
logging.debug("deg msg")
logging.info("info msg")
logging.warning("warning msg")
logging.error("error msg")
logging.critical("critical msg")

2.自定义logging

import logging
# 设置logging等级,低于该等级消息不会出现,默认等级level=logging.WARNING
# 等级顺序从低至高依次为debug,info,warning,error,critical
test_logger=logging.getLogger("test_logger")
file_handler=logging.FileHandler("test_logger.txt",'w')
file_handler.setFormatter(logging.Formatter("%(asctime)s-%(name)s-%(levelno)s"))
test_logger.addHandler(file_handler)
test_logger.error("error mgs")

3.用logging记录异常 

import logging
# 设置logging等级,低于该等级消息不会出现,默认等级level=logging.WARNING
# 等级顺序从低至高依次为debug,info,warning,error,critical
test_logger=logging.getLogger("test_logger")
file_handler=logging.FileHandler("test_logger_get_exception.txt",'w')
file_handler.setFormatter(logging.Formatter("%(asctime)s-%(name)s-%(levelno)s"))
test_logger.addHandler(file_handler)
try:1/0
except:test_logger.exception("Get exception")

学习资料连接:

[Python] logging模块怎么用_哔哩哔哩_bilibili

4.python logging.basicConfig参数

logging.basicConfig 是 Python logging 模块中用于配置日志记录的一个方便函数。以下是对其主要参数的详细解释:

参数说明

  • filename

    • 类型:str
    • 作用:指定日志输出的文件名。如果提供了此参数,日志信息将被写入文件而不是控制台。
    • 示例:
     

    收起

    python

    import logging
    logging.basicConfig(filename='example.log')
    
  • filemode

    • 类型:str
    • 作用:指定文件的打开模式,默认为 'a'(追加模式),可以使用 'w'(写入模式)。
    • 示例:
     

    收起

    python

    import logging
    logging.basicConfig(filename='example.log', filemode='w')
    
  • format

    • 类型:str
    • 作用:指定日志消息的格式。使用特定的格式字符串来定义日志消息的外观。
    • 常见格式占位符:
      • %(asctime)s:日志的时间,默认为 '2003-07-08 16:49:45,896' 这种形式。
      • %(levelname)s:日志级别,如 DEBUGINFOWARNINGERRORCRITICAL
      • %(name)s:日志记录器的名称。
      • %(message)s:日志消息。
      • %(levelno)s:日志级别的数字表示。
    • 示例:
     

    收起

    python

    import logging
    logging.basicConfig(format='%(asctime)s - %(levelname)s - %(message)s')
    
  • datefmt

    • 类型:str
    • 作用:指定日期 / 时间的格式,与 %(asctime)s 一起使用。
    • 示例:
     

    收起

    python

    import logging
    logging.basicConfig(format='%(asctime)s - %(levelname)s - %(message)s', datefmt='%Y-%m-%d %H:%M:%S')
    
  • level

    • 类型:int 或 str
    • 作用:设置日志的最低输出级别。低于此级别的日志消息将被忽略。可以使用 logging.DEBUGlogging.INFOlogging.WARNINGlogging.ERRORlogging.CRITICAL 或相应的整数(10, 20, 30, 40, 50)。
    • 示例:
     

    收起

    python

    import logging
    logging.basicConfig(level=logging.INFO)
    
  • handlers

    • 类型:list
    • 作用:指定日志处理器列表。可以将日志信息发送到多个目标,如文件、控制台、邮件等。
    • 示例:
     

    收起

    python

    import logging
    from logging.handlers import RotatingFileHandler
    handler = RotatingFileHandler('example.log', maxBytes=2000, backupCount=5)
    logging.basicConfig(handlers=[handler])
    

示例

以下是一个综合使用 logging.basicConfig 的示例:

收起

python

import logginglogging.basicConfig(filename='example.log',filemode='w',format='%(asctime)s - %(levelname)s - %(message)s',datefmt='%Y-%m-%d %H:%M:%S',level=logging.INFO
)# 输出不同级别的日志
logging.debug('This is a debug message')
logging.info('This is an info message')
logging.warning('This is a warning message')
logging.error('This is an error message')
logging.critical('This is a critical message')

解释

  • filename='example.log' 和 filemode='w' 表示将日志信息以写入模式保存到 example.log 文件中。
  • format='%(asctime)s - %(levelname)s - %(message)s' 和 datefmt='%Y-%m-%d %H:%M:%S' 定义了日志消息的格式和日期格式。
  • level=logging.INFO 表示只输出 INFO 及以上级别的日志信息。

注意事项

  • 一旦调用 logging.basicConfig 并设置了配置,后续调用不会重新配置日志系统,除非使用 force=True 参数。
  • 对于更复杂的日志需求,可能需要使用 LoggerHandlerFormatter 等类进行更详细的日志系统配置。

通过使用 logging.basicConfig 的这些参数,可以方便地设置基本的日志记录功能,满足大多数简单的日志需求。对于更复杂的日志系统,可以深入研究 logging 模块的其他部分,如 FileHandlerStreamHandlerFormatter 等。

除了logging.basicConfig,还有哪些方法可以配置Python的日志记录?

如何在日志消息中包含更多的上下文信息?

如何在生产环境中配置日志记录?

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【JavaSE】(8) String 类

一、String 类常用方法 1、构造方法 常用的这4种构造方法:直接法,或者传参字符串字面量、字符数组、字节数组。 在 JDK1.8 中,String 类的字符串实际存储在 char 数组中: String 类也重写了 toString 方法,所以可以直…

【理解工具调用的流程,本质体现了大模型智能性】

1、工具调用 调用完结果看里面tool_calls 是否为空,不为空就调用工具函数处理, 如果为空就中断循环。大模型返回的message结果智能判断是否继续调用 输入输出如下: 请输入:深圳西安天气 ------------------------------------…

excel实用工具

持续更新… 文章目录 1. 快捷键1.1 求和 2. 命令2.1 查找 vloopup 1. 快捷键 1.1 求和 windows: alt mac : command shift T 2. 命令 2.1 查找 vloopup vlookup 四个入参数 要查找的内容 (A2 6xx1)查找的备选集 (C2:C19)…

【C++】模板(进阶)

本篇我们来介绍更多关于C模板的知识。模板初阶移步至:【C】模板(初阶) 1.非类型模板参数 1.1 非类型模板参数介绍 模板参数可以是类型形参,也可以是非类型形参。类型形参就是我们目前接触到的一些模板参数。 //类型模板参数 …

一文学会YOLO系列算法(从V3到11)实现遥感图像目标检测

目录 前言 数据集介绍 数据集转换 YOLO代码的下载 YOLO的配置 1.数据集的配置 2.模型的配置 YOLO11模型的训练 其它版本YOLO的训练 前言 遥感技术的快速发展,特别是在高分辨率遥感图像的获取能力上的显著提升,已经大大拓宽了遥感数据在环境监测…

图解Git——分布式Git《Pro Git》

分布式工作流程 Centralized Workflow(集中式工作流) 所有开发者都与同一个中央仓库同步代码,每个人通过拉取、提交来合作。如果两个开发者同时修改了相同的文件,后一个开发者必须在推送之前合并其他人的更改。 Integration-Mana…

【高阶数据结构】布隆过滤器(BloomFilter)

1. 概念 1.1 背景引入 背景:在计算机软件中,一个常见的需求就是 在一个集合中查找一个元素是否存在 ,比如:1. Word 等打字软件需要判断用户键入的单词是否在字典中存在 2. 浏览器等网络爬虫程序需要保存一个列表来记录已经遍历过…

【json_object】mysql中json_object函数过长,显示不全

问题:json只显示部分 解决: SET GLOBAL group_concat_max_len 1000000; -- 设置为1MB,根据需要调整如果当前在navicat上修改,只有效本次连接和后续会话,重新连接还是会恢复默认值1024 在my.ini配置文件中新增或者修…

计算机网络 (52)秘钥分配

一、重要性 在计算机网络中,密钥分配是密钥管理中的一个核心问题。由于密码算法通常是公开的,因此网络的安全性主要依赖于密钥的安全保护。密钥分配的目的是确保密钥在传输过程中不被窃取或篡改,同时确保只有合法的用户才能获得密钥。 二、方…

第35天:安全开发-JavaEE应用原生反序列化重写方法链条分析触发类类加载

时间轴: 序列化与反序列化图解: 演示案例: Java-原生使用-序列化&反序列化 Java-安全问题-重写方法&触发方法 Java-安全问题-可控其他类重写方法 Java-原生使用-序列化&反序列化 1.为什么进行序列化和反序列化&#xff1…

MindAgent:基于大型语言模型的多智能体协作基础设施

2023-09-18 ,加州大学洛杉矶分校(UCLA)、微软研究院、斯坦福大学等机构共同创建的新型基础设施,目的在评估大型语言模型在游戏互动中的规划和协调能力。MindAgent通过CuisineWorld这一新的游戏场景和相关基准,调度多智…

Excel 技巧17 - 如何计算倒计时,并添加该倒计时的数据条(★)

本文讲如何计算倒计时,并添加该倒计时的数据条。 1,如何计算倒计时 这里也要用公式 D3 - TODAY() 显示为下面这个样子的 然后右键该单元格,选 设置单元格格式 然后点 常规 这样就能显示出还书倒计时的日数了。 下拉适用到其他单元格。 2&a…

rocketmq基本架构

简介 Name server 负责broker注册、心跳,路由等功能,类似Kafka的ZKname server节点之间不互相通信,broker需要和所有name server进行通信。扩容name server需要重启broker,不然broker不会和name server建立连接producer和consum…

国产编辑器EverEdit - 大纲视图

1 大纲视图 1.1 应用场景 在编辑较长代码文件时,使用大纲视图可以方便的检视当前文件的变量、函数等信息,方便在不同函数间跳转,对整个文档的全貌了然于胸。   在编辑XML文档时,通过展示XML文件的层次结构、节点布局&#xff0…

Linux中的基本指令(一)

一、Linux中指令的存在意义 Linux中,通过输入指令来让操作系统执行,以此达到控制操作系统的目的,类似于Windows中的双击,右键新建文件,新建文件夹等 1.补:关于屏幕的几个操作指令 ①清屏指令 clear 回…

2025/1/21 学习Vue的第四天

睡觉。 --------------------------------------------------------------------------------------------------------------------------------- 11.Object.defineProperty 1.在我们之前学习JS的时候&#xff0c;普通得定义一个对象与属性。 <!DOCTYPE html> <h…

Go Map 源码分析(一)

Go语言中的map是通过哈希表实现的&#xff0c;其底层结构和实现机制如下&#xff1a; 一、hash 结构 hmap结构体&#xff1a;是map的头部结构&#xff0c;主要字段及含义如下&#xff1a; count&#xff1a;表示当前哈希表中的元素数量&#xff0c;与len()函数相对应。flags…

Linux-C/C++--深入探究文件 I/O (上)(文件的管理、函数返回错误、exit()、_Exit()、_exit())

经过上一章内容的学习&#xff0c;相信各位读者对 Linux 系统应用编程中的基础文件 I/O 操作有了一定的认识和理解了&#xff0c;能够独立完成一些简单地文件 I/O 编程问题&#xff0c;如果你的工作中仅仅只是涉及到一些简单文件读写操作相关的问题&#xff0c;其实上一章的知识…

【机器学习实战中阶】音乐流派分类-自动化分类不同音乐风格

音乐流派分类 – 自动化分类不同音乐风格 在本教程中,我们将开发一个深度学习项目,用于自动化地从音频文件中分类不同的音乐流派。我们将使用音频文件的频率域和时间域低级特征来分类这些音频文件。 对于这个项目,我们需要一个具有相似大小和相似频率范围的音频曲目数据集…

Walrus Learn to Earn计划正式启动!探索去中心化存储的无限可能

本期 Learn to Earn 活动将带领开发者和区块链爱好者深入探索 Walrus 的技术核心与实际应用&#xff0c;解锁分布式存储的无限可能。参与者不仅能提升技能&#xff0c;还能通过完成任务赢取丰厚奖励&#xff01;&#x1f30a; 什么是 Walrus&#xff1f; 数据主权如今正成为越…