当前位置: 首页 > news >正文

python代码编写规范及注意事项

目录

  • 1. 注意
    • 1.1 变量与常量
      • 解释:
      • 建议的修复:
    • 1.2 Too many arguments 和 Too many local variables
      • 解决方案
        • 1. 减少参数数量
        • 2. 减少局部变量数量
        • 3. 调整 Pylint 配置
      • 总结

1. 注意

1.1 变量与常量

解读下面的pylint问题
C0103: Constant name “file_path5” doesn’t conform to UPPER_CASE naming style (invalid-name)

变量:小写如num1
常量:大写如MAX_VALUE、FILE_PATH_5等

Pylint 警告 C0103: 常量名 “file_path5” 不符合 UPPER_CASE 命名风格 (invalid-name) 表示变量 file_path5 不遵循 Python 中常量的命名约定。

解释:

  1. 命名约定:在 Python 中,常量通常使用大写字母表示,并且单词之间用下划线分隔。这是根据 PEP 8(Python 代码的风格指南)广泛接受的约定。例如,一个常量可能被命名为 FILE_PATHMAX_VALUE

  2. 你的变量:名称 file_path5 使用小写字母,混合了字母和数字,这不符合预期的 UPPER_CASE 风格。这可能导致混淆,因为不容易立即看出 file_path5 是一个常量。

建议的修复:

为了解决这个警告,你应该将常量重命名为符合 UPPER_CASE 约定。例如,你可以将 file_path5 更改为 FILE_PATH_5,或者如果数字不是必要的,可以使用 FILE_PATH

以下是你可以更新代码的方式:

FILE_PATH_5 = "/path/to/file"

通过遵循这个约定,你的代码将更具可读性和可维护性,并且符合 Python 社区的标准。

1.2 Too many arguments 和 Too many local variables

def main(df_loc: pd.DataFrame, df_ti: pd.DataFrame, df_ti_matrix: pd.DataFrame, ws_frequency_matrix: pd.DataFrame,df_list: List[str], v50_list: List[float], v50_limit: float = 37.5) -> Dict[str, Union[str, float, List[float], bool]]:

在执行pylint代码格式检查的时候,出现了下面的错误:

terrain_adaptation_cal_ewm.py:638:0: R0913: Too many arguments (7/5) (too-many-arguments)
terrain_adaptation_cal_ewm.py:638:0: R0914: Too many local variables (17/15) (too-many-locals)

分析如下:

在上述的代码中,Pylint 报告了两个错误:

  1. R0913: Too many arguments (7/5) (too-many-arguments)

    • 这个警告表示函数 main 的参数数量超过了 Pylint 设定的默认限制(5 个参数)。在 Python 中,函数参数过多可能使函数变得难以理解和使用,增加了维护的复杂性。
  2. R0914: Too many local variables (17/15) (too-many-locals)

    • 这个警告表示函数 main 中定义的局部变量数量超过了 Pylint 的默认限制(15 个局部变量)。局部变量过多可能会降低代码的可读性和可维护性。

解决方案

为了修复这些警告,可以采用以下几种方法:

1. 减少参数数量
  • 使用数据类或字典:如果函数参数过多,可以考虑将相关参数组合成一个数据类(dataclass)或者字典。例如,可以将 df_locdf_tidf_ti_matrix 组合为一个数据类。
from dataclasses import dataclass
import pandas as pd
from typing import List, Dict, Union@dataclass
class DataFrames:df_loc: pd.DataFramedf_ti: pd.DataFramedf_ti_matrix: pd.DataFramews_frequency_matrix: pd.DataFramedef main(dataframes: DataFrames, df_list: List[str], v50_list: List[float], v50_limit: float = 37.5) -> Dict[str, Union[str, float, List[float], bool]]:# 函数内部逻辑
2. 减少局部变量数量
  • 重构代码:如果函数中局部变量过多,可以考虑将一些逻辑提取到单独的辅助函数中。这样不仅可以减少局部变量的数量,还能提高代码的可读性。
def helper_function(...):# 处理某个特定的逻辑return resultdef main(...):# 使用 helper_function 处理某些逻辑
3. 调整 Pylint 配置

如果你认为你的函数参数和局部变量数量是合理的,并且改变这些结构会导致代码的可读性下降,可以考虑调整 Pylint 的配置文件,增加这些限制的阈值。

.pylintrc 文件中,你可以修改以下设置:

[FORMAT]
# 最大参数数量
max-args=10# 最大局部变量数量
max-locals=20

总结

通过重构代码、使用数据结构组合参数、或者调整 Pylint 的配置,你可以有效地解决这些警告,提高代码的可读性和可维护性。

相关文章:

python代码编写规范及注意事项

目录 1. 注意1.1 变量与常量解释:建议的修复: 1.2 Too many arguments 和 Too many local variables解决方案1. 减少参数数量2. 减少局部变量数量3. 调整 Pylint 配置 总结 1. 注意 1.1 变量与常量 解读下面的pylint问题 C0103: Constant name “file_p…...

【Linux】命令行参数 | 环境变量

🪐🪐🪐欢迎来到程序员餐厅💫💫💫 主厨:邪王真眼 主厨的主页:Chef‘s blog 所属专栏:青果大战linux 总有光环在陨落,总有新星在闪烁 前几天在搞硬件&…...

python 使用进程池并发执行 SQL 语句

这段代码使用了 Python 的 multiprocessing 模块来实现真正的并行处理,绕过 Python 的全局解释器锁(GIL)限制,从而在多核 CPU 上并发执行多个 SQL 语句。 from pyhive import hive import multiprocessing# 建立连接 conn hive.…...

我也谈AI

“随着人工智能技术的不断发展,我们已经看到了它在各行业带来的巨大变革。在医疗行业中,人工智能技术正在被应用于病例诊断、药物研发等方面,为医学研究和临床治疗提供了新的思路和方法;在企业中,人工智能技术可以通过…...

算法妙妙屋-------1.递归的深邃回响:二叉树的奇妙剪枝

大佬们好呀,这一次讲解的是二叉树的深度搜索,大佬们请阅 1.前言 ⼆叉树中的深搜(介绍) 深度优先遍历(DFS,全称为DepthFirstTraversal),是我们树或者图这样的数据结构中常⽤的⼀种…...

编写第一个 Appium 测试脚本:从安装到运行!

前言 最近接到一个测试项目,简单描述一下,需求就是:一端发送指令,另一端接受指令并处理指令。大概看了看有上百条指令,点点点岂不是废了,而且后期迭代,每次都需要点点点,想想就头大…...

mysql查表相关练习

作业要求: 单表练习: 1 . 查询出部门编号为 D2019060011 的所有员工 2 . 所有财务总监的姓名、编号和部门编号。 3 . 找出奖金高于工资的员工。 4 . 找出奖金高于工资 40% 的员工。 5 找出部门编号为 D2019090011 中所有财务总监,和…...

airtest+poco多脚本、多设备批处理运行测试用例自动生成测试报告

一:主要内容 框架功能、框架架构及测试报告效果 airtest安装、环境搭建 框架搭建、框架运行说明 框架源码 二:框架功能及测试报告效果 1. 框架功能: 该框架笔者用来作为公司的项目的前端自动化,支持pc和app,本文…...

Prometheus套装部署到K8S+Dashboard部署详解

1、添加helm源并更新 helm repo add prometheus-community https://prometheus-community.github.io/helm-charts helm repo update2、创建namespace kubectl create namespace monitoring 3、安装Prometheus监控套装 helm install prometheus prometheus-community/prome…...

python使用pymysql

为了封装这个数据库操作为一个通用方法,我们可以创建一个函数,该函数接受数据库连接参数(如主机名、用户名、密码、数据库名)、SQL语句以及必要的参数(用于参数化查询)。下面是一个简单的封装示例&#xff…...

Vue3 + TypeScript 组件和文件命名规范及 setup 导入顺序规范

前言 在 Vue3 项目中,合理的文件命名规范和导入顺序不仅有助于提高代码的可读性,还能增强团队协作的效率。特别是在使用 TypeScript 和 Composition API 的项目中,清晰的组件和文件结构尤为重要。本文将详细介绍 Vue3 TypeScript 项目中的组…...

netty之处理连接源码分析

写在前面 在这篇文章看了netty服务是如何启动的,服务启动成功后,也就相当于是迎宾工作都已经准备好了,那么当客人来了怎么招待客人呢?也就是本文要看的处理连接的工作。 1:正文 先启动源码example模块的echoserver&a…...

Dockerfile文件编写

1、打nginx原始包 登录后复制 ROM nginxENV LANG zh_CN.UTF-8 ENV LC_ALL zh_CN.UTF-8 ENV TZ Asia/Singapore# 设置时区,同样保持在一层 RUN ln -sf /usr/share/zoneinfo/${TZ} /etc/localtime && \echo "${TZ}" > /etc/timezoneRUN apt-get …...

Oracle SQL 使用 ROWNUM 分页查询速度太慢的问题及解决方案!

在使用 Oracle 数据库进行数据查询时,分页查询是一种常见的需求。传统上,开发者常常使用 ROWNUM 来实现分页功能。 然而,当数据量较大时,使用 ROWNUM 进行分页查询可能会导致性能问题。本文将深入探讨这一问题的原因,并提供多种解决方案,以提高分页查询的性能。 一、RO…...

Django3 + Vue.js 前后端分离书籍添加项目Web开发实战

文章目录 Django3后端项目创建切换数据库创建Django实战项目App新建Vue.js前端项目 Django3后端项目创建 创建Django项目,采用Pycharm或者命令行创建皆可。此处,以命令行方式作为演示,项目名为django_vue。 django-admin startproject djang…...

楼梯区域分割系统:Web效果惊艳

楼梯区域分割系统源码&数据集分享 [yolov8-seg-FocalModulation&yolov8-seg-GFPN等50全套改进创新点发刊_一键训练教程_Web前端展示] 1.研究背景与意义 项目参考ILSVRC ImageNet Large Scale Visual Recognition Challenge 项目来源AAAI Global Al l…...

Day10加一

给定一个由 整数 组成的 非空 数组所表示的非负整数,在该数的基础上加一。 最高位数字存放在数组的首位, 数组中每个元素只存储单个数字。 你可以假设除了整数 0 之外,这个整数不会以零开头。 class Solution {public int[] plusOne(int[] di…...

UTF-8简介

UTF-8 UTF-8(8-bit Unicode Transformation Format)是一种针对Unicode的可变长度字符编码,也是一种前缀码。它可以用一至四个字节对Unicode字符集中的所有有效编码点进行编码,属于Unicode标准的一部分,最初由肯汤普逊…...

基于Openwrt系统架构,实现应用与驱动的实例。

一、在openwrt系统架构,编写helloworld的应用程序。 第一步先创建目录,项目代码要放在 openwrt根目下的 package 目录中,这里源码写在了 hellworld 的 src 目录下,因为外层还有需要编写的文件。 mkdir -p ~/openwrt/package/hel…...

SQL进阶技巧:如何利用三次指数平滑模型预测商品零售额?

目录 0 问题背景 1 数据准备 2 问题解决 2.1 模型构建 (1)符号规定 (2)基本假设...

RestClient

什么是RestClient RestClient 是 Elasticsearch 官方提供的 Java 低级 REST 客户端,它允许HTTP与Elasticsearch 集群通信,而无需处理 JSON 序列化/反序列化等底层细节。它是 Elasticsearch Java API 客户端的基础。 RestClient 主要特点 轻量级&#xff…...

观成科技:隐蔽隧道工具Ligolo-ng加密流量分析

1.工具介绍 Ligolo-ng是一款由go编写的高效隧道工具,该工具基于TUN接口实现其功能,利用反向TCP/TLS连接建立一条隐蔽的通信信道,支持使用Let’s Encrypt自动生成证书。Ligolo-ng的通信隐蔽性体现在其支持多种连接方式,适应复杂网…...

装饰模式(Decorator Pattern)重构java邮件发奖系统实战

前言 现在我们有个如下的需求,设计一个邮件发奖的小系统, 需求 1.数据验证 → 2. 敏感信息加密 → 3. 日志记录 → 4. 实际发送邮件 装饰器模式(Decorator Pattern)允许向一个现有的对象添加新的功能,同时又不改变其…...

调用支付宝接口响应40004 SYSTEM_ERROR问题排查

在对接支付宝API的时候,遇到了一些问题,记录一下排查过程。 Body:{"datadigital_fincloud_generalsaas_face_certify_initialize_response":{"msg":"Business Failed","code":"40004","sub_msg…...

《Qt C++ 与 OpenCV:解锁视频播放程序设计的奥秘》

引言:探索视频播放程序设计之旅 在当今数字化时代,多媒体应用已渗透到我们生活的方方面面,从日常的视频娱乐到专业的视频监控、视频会议系统,视频播放程序作为多媒体应用的核心组成部分,扮演着至关重要的角色。无论是在个人电脑、移动设备还是智能电视等平台上,用户都期望…...

(二)原型模式

原型的功能是将一个已经存在的对象作为源目标,其余对象都是通过这个源目标创建。发挥复制的作用就是原型模式的核心思想。 一、源型模式的定义 原型模式是指第二次创建对象可以通过复制已经存在的原型对象来实现,忽略对象创建过程中的其它细节。 📌 核心特点: 避免重复初…...

2025 后端自学UNIAPP【项目实战:旅游项目】6、我的收藏页面

代码框架视图 1、先添加一个获取收藏景点的列表请求 【在文件my_api.js文件中添加】 // 引入公共的请求封装 import http from ./my_http.js// 登录接口(适配服务端返回 Token) export const login async (code, avatar) > {const res await http…...

【Oracle】分区表

个人主页:Guiat 归属专栏:Oracle 文章目录 1. 分区表基础概述1.1 分区表的概念与优势1.2 分区类型概览1.3 分区表的工作原理 2. 范围分区 (RANGE Partitioning)2.1 基础范围分区2.1.1 按日期范围分区2.1.2 按数值范围分区 2.2 间隔分区 (INTERVAL Partit…...

Springboot社区养老保险系统小程序

一、前言 随着我国经济迅速发展,人们对手机的需求越来越大,各种手机软件也都在被广泛应用,但是对于手机进行数据信息管理,对于手机的各种软件也是备受用户的喜爱,社区养老保险系统小程序被用户普遍使用,为方…...

【Go语言基础【13】】函数、闭包、方法

文章目录 零、概述一、函数基础1、函数基础概念2、参数传递机制3、返回值特性3.1. 多返回值3.2. 命名返回值3.3. 错误处理 二、函数类型与高阶函数1. 函数类型定义2. 高阶函数(函数作为参数、返回值) 三、匿名函数与闭包1. 匿名函数(Lambda函…...