python自动化学习--3.8python操作EXCEL文件python日志收集处理

news2024/11/20 14:32:46

1、Excel文件处理

安装 openpxl 第三方库

openpxl 模块三大组件:

1、工作簿 (包含多个sheet工作表)

2、工作表 (某个数据包含在某个工作表)

3、单元格

1、创建excel工作簿

import openpyxl

"""
    Excel表格的创建
"""


def createExcel():
    # 创建工作簿
    wk = openpyxl.Workbook()
    # 获取当前工作表
    sheet = wk.active
    # 写数据到单元格
    sheet.cell(1, 1).value = "username"
    sheet.cell(1, 2).value = "class"
    sheet.cell(1, 3).value = "adress"
    wk.save("userinfo.xlsx")


if __name__ == '__main__':
    createExcel()

run后会生成一个userinfo.xlsx工作簿,内容:

2、读取工作表

"""
    2、读取Excel表格的数据
"""
def readExcel():
    # 读取工作簿
    wk = openpyxl.load_workbook("userinfo.xlsx")
    # 方式一:获取工作表
    sheet1 = wk.get_sheet_by_name("Sheet")
    # 方式二:获取工作表
    # sheet1 = wk["Sheet"]
    # 获取单元格坐标
    locaion = sheet1.cell(1, 1)
    value = sheet1.cell(1, 1).value
    print(locaion, value)
    rows = sheet1.max_row
    cols = sheet1.max_column
    print(f"工作表行数={rows}, 列数={cols}")

3、编辑工作表

先加载excel表格 然后修改数据后 保存 就ok

2、日志处理

1、日志作用:

问题定位、信息查询、数据分析

2、内置模块:logging

logging的四大组件:

1、日志器Logger -- > 入口

2、处理器 Handler ---> 执行者 在哪个端输出 (日志文件 or 控制台)

3、格式器 Fomatter 旗帜输入的内容

4、过滤器 Filter  输出感兴趣日志信息 过滤掉不感兴趣的日志信息

关系:1个日志器可以有多个处理器

每个处理器可以有各自的各时期和过滤器

3、logging模块的应用

日志级别:

debug  调试信息

info  关键时间描述  比如 在什么时间做了什么事情

warning 警告信息

error 错误信息

critical  严重错误信息

案例1 如下:

import  logging

# 创建日志器
logger = logging.getLogger("logger")
# 创建控制台处理器  ---》 日志会输出在控制台
SH = logging.StreamHandler()
# 创建文件处理器  ---》 那么日志会输出到文件里面
FH = logging.FileHandler("log.txt")

# 日志包含哪些内容 时间  文件 日志级别  日志信息
formatter = logging.Formatter(fmt="[%(asctime)s][%(filename)s] %(levelname)s : %(message)s",
                              datefmt="%Y/%m/%d %H:%M:%S")
logger.addHandler(SH)
logger.addHandler(FH)
SH.setFormatter(formatter)

# 假设有报错
try:
    score = int(input("请输入你的成绩"))
    if score > 60:
        print("恭喜你通过")
    else:
        print("继续努力")

    logging.debug("这是一个debug信息")
    logger.info("你查询成绩成功")
    logging.warning("这是一个警告信息")

except Exception as error:
     logger.error("输入不是数字, 错误信息:"+str(error))
     logger.critical("这是一个critical信息")



如果想封装成一个方法的话, 如下

import  logging

class FrameLog:

    def getLogger(self):

        # 创建日志器
        logger = logging.getLogger("logger")
        logger.setLevel(logging.INFO)
        # 如果没有处理器
        if not logger.handlers:

            # 创建控制台处理器  ---》 日志会输出在控制台
            SH = logging.StreamHandler()
            # 创建文件处理器  ---》 那么日志会输出到文件里面
            FH = logging.FileHandler("log.txt")

            # 日志包含哪些内容 时间  文件 日志级别  日志信息
            formatter = logging.Formatter(fmt="[%(asctime)s][%(filename)s] %(levelname)s : %(message)s",
                                      datefmt="%Y/%m/%d %H:%M:%S")
            logger.addHandler(SH)
            logger.addHandler(FH)
            SH.setFormatter(formatter)

        return logger

    def sum_two(self, x, y):
        """
                求多个数之和
                :param args:
                :return:
                """
        sum_two = 0
        try:
            sum_two = x + y
            self.getLogger().info(f"计算2个数之和={sum_two}")
            return sum_two
        except Exception as error:
            self.getLogger().error("计算2个数之和有异常:\n"+str(error))

    def sum(self, *args):
        """
        求多个数之和
        :param args:
        :return:
        """

        try:
            sum = 0
            for num in args:
                sum+=num

        except Exception as error:
            self.getLogger().error("计算多个数之和有异常:\n"+str(error))
        self.getLogger().info(f"计算多个数之和={sum}")
        return sum


if __name__ == '__main__':
    FrameLog().sum(9,2,3)
    FrameLog().sum_two(1,2)

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

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

相关文章

存内计算技术大幅提升机器学习算法的性能—挑战与解决方案探讨

一.存内计算技术大幅机器学习算法的性能 1.1背景 人工智能技术的迅速发展使人工智能芯片成为备受关注的关键组成部分。在人工智能的构建中,算力是三个支柱之一,包括数据、算法和算力。目前,人工智能芯片的发展主要集中在两个方向&#xff1…

好物周刊#42:国产项目管理软件

https://github.com/cunyu1943 村雨遥的好物周刊,记录每周看到的有价值的信息,主要针对计算机领域,每周五发布。 一、项目 1. 菠萝博客 基于 Java 的菠萝博客系统,简单易部署,精致主题,贴心服务&#xf…

1 数据分析概述与职业操守

1、 EDIT数字化模型 E——exploration探索 (是什么) 业务运行探索:探索关注企业各项业务的运行状态、各项指标是否合规以及各项业务的具体数据情况等。 指标体系——目标(O)、策略(S)、指标&a…

推荐系统经典模型YouTubeDNN代码

文章目录 前言数据预处理部分模型训练预测部分总结与问答 前言 上一篇讲到过YouTubeDNN论文部分内容,但是没有代码部分。最近网上教学视频里看到一段关于YouTubeDNN召回算法的代码,现在我分享一下给大家参考看一下,并附上一些我对代码的理解…

C++——类和对象(1)

1. 类 我们之前提及过C语言是面向过程的语言,其解决问题的方式是关注问题过程,然后逐步解决。而C是面向对象编程,聚焦于对象,依靠多个对象之间的交互关系解决问题。而类这个概念的引入则是面向对象的最深刻体现。 1.1 C中的结构体…

二叉树的增删查改

本节复习二叉树的增删查改, 二叉树的知识相对于前面的循序表, 链表, 以及栈和队列都要多一些。 同时二叉树的增删查改理解起来相对来说要困难一些。 本节来好好复习一下二叉树的增删查改。 目录 准备文件 创建结构体蓝图 二叉树的前序遍历…

【数据分享】2001-2022年我国省市县镇四级的逐日平均降水量数据(免费获取\excel\shp格式)

降水数据是我们在各项研究中最常用的气象指标之一!之前我们给大家分享过来源于国家青藏高原科学数据中心发布的1961—2022年全国范围的逐日降水栅格数据(可查看之前的文章获悉详情)! 本次我们分享的是2001-2002年我国省市县镇四个…

【中科院计算所】WSDM 2024冠军方案:基于大模型进行多文档问答

作者:李一鸣 张兆 中科院计算所 会话式多文档问答旨在根据检索到的文档以及上下文对话来回答特定问题。 在本文中,我们介绍了 WSDM Cup 2024 中“对话式多文档 QA”挑战赛的获胜方法,该方法利用了大型语言模型 (LLM) 卓越的自然语言理解和生…

Pyhton的组合数据类型

归纳编程学习的感悟, 记录奋斗路上的点滴, 希望能帮到一样刻苦的你! 如有不足欢迎指正! 共同学习交流! 🌎欢迎各位→点赞 👍 收藏⭐ 留言​📝 生命对某些人来说是美丽的&#xff0c…

二分查找讲解

关于我为什么要写单独开一篇文章写二分,实际上那么多困难的算法,比如线段树,并查集等等都没有难倒我,我最近却被二分难倒了,而且是两次,两次在赛场上做不出来二分的应用题,于是我决定写一篇二分查找的算法总结.刚接触算法的时候本来是要写一篇的,但后面因为各种原因搁置了,现在…

lv20 QT主窗口

熟悉创建主窗口项目 1 QAction 2 主窗口 菜单栏:fileMenu menuBar()->addMenu(tr("&File")); 工具栏:fileToolBar addToolBar(tr("File")); 浮动窗:QDockWidget *dockWidget new QDockWidget(tr("Dock W…

云上攻防-云服务篇弹性计算服务器云数据库实例元数据控制角色AK控制台接管

知识点: 1、云服务-弹性计算服务器-元数据&SSRF&AK 2、云服务-云数据库-外部连接&权限提升 章节点: 云场景攻防:公有云,私有云,混合云,虚拟化集群,云桌面等 云厂商攻防:阿里云&am…

Pytorch学习 day01(Jupyter安装

Jupyter 安装过程中遇到的问题: Anaconda的base环境会自动安装Jupyter,但是如果我们要在其他环境中安装Jupyter,就需要注意,该环境的python版本不能高于3.11,且用以下代码安装: conda install nb_conda_…

深度学习 精选笔记(8)梯度消失和梯度爆炸

学习参考: 动手学深度学习2.0Deep-Learning-with-TensorFlow-bookpytorchlightning ①如有冒犯、请联系侵删。 ②已写完的笔记文章会不定时一直修订修改(删、改、增),以达到集多方教程的精华于一文的目的。 ③非常推荐上面(学习参考&#x…

微信小程序 vs 公众号商城:亿发解密线上业务的最佳选择之道

在拓展线上业务的道路上,搭建线上商城成为企业首要选择。然而,在选择小程序商城和公众号商城时,很多企业陷入了两者之间的纠结。本文将深入解答小程序商城和公众号商城的概念、区别,并为您提供明智的选择建议。 一、小程序商城和公…

Flutter开发之Slider

Flutter开发之Slider 本文是关于介绍Slider相关属性的含义。 class SliderThemeData {/// slider轨道的高度 final double? trackHeight; /// 滑块滑过的轨道颜色 final Color? activeTrackColor; /// 滑块未滑过的轨道颜色 final Color? inactiveTrackColor; /// 滑块滑过…

多人同时导出 Excel 干崩服务器?我们来实现一个排队导出功能!

考虑到数据库数据日渐增多,导出会有全量数据的导出,多人同时导出可以会对服务性能造成影响,导出涉及到mysql查询的io操作,还涉及文件输入、输出流的io操作,所以对服务器的性能会影响的比较大; 结合以上原因…

李沐动手学习深度学习——3.2练习

以下是个人理解,希望进行讨论求解。 练习 1. 如果我们将权重初始化为零,会发生什么。算法仍然有效吗? 根据SGD算法公式如上,第一次迭代的值可知w只与b相关,而对于b的迭代更新,只是与b的初始值相关&#x…

什么是物联网?

今天这篇文章写的相关内容就是带领大家了解什么是物联网,之前写的文章大多都是一些物联网的未来,行业的解决方案等;话不多说开始进入正题吧! 物联网(IoT)是一个包罗万象的术语,指的是越来越多的电子产品,它们不是传统的…

【2022 J1】乘方

本主又双叒叕来更新了,一圈三连不用说了吧😁 本题是J组第二轮的题: 题目描述 小文同学刚刚接触了信息学竞赛,有一天她遇到了这样一个题:给定正整数 a 和 b,求 ��ab 的值是多少。 …