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 中常量的命名约定。
解释:
-
命名约定:在 Python 中,常量通常使用大写字母表示,并且单词之间用下划线分隔。这是根据 PEP 8(Python 代码的风格指南)广泛接受的约定。例如,一个常量可能被命名为
FILE_PATH
或MAX_VALUE
。 -
你的变量:名称
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 报告了两个错误:
-
R0913: Too many arguments (7/5) (too-many-arguments):
- 这个警告表示函数
main
的参数数量超过了 Pylint 设定的默认限制(5 个参数)。在 Python 中,函数参数过多可能使函数变得难以理解和使用,增加了维护的复杂性。
- 这个警告表示函数
-
R0914: Too many local variables (17/15) (too-many-locals):
- 这个警告表示函数
main
中定义的局部变量数量超过了 Pylint 的默认限制(15 个局部变量)。局部变量过多可能会降低代码的可读性和可维护性。
- 这个警告表示函数
解决方案
为了修复这些警告,可以采用以下几种方法:
1. 减少参数数量
- 使用数据类或字典:如果函数参数过多,可以考虑将相关参数组合成一个数据类(dataclass)或者字典。例如,可以将
df_loc
、df_ti
和df_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语句以及必要的参数(用于参数化查询)。下面是一个简单的封装示例ÿ…...
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)基本假设...
生成xcframework
打包 XCFramework 的方法 XCFramework 是苹果推出的一种多平台二进制分发格式,可以包含多个架构和平台的代码。打包 XCFramework 通常用于分发库或框架。 使用 Xcode 命令行工具打包 通过 xcodebuild 命令可以打包 XCFramework。确保项目已经配置好需要支持的平台…...

遍历 Map 类型集合的方法汇总
1 方法一 先用方法 keySet() 获取集合中的所有键。再通过 gey(key) 方法用对应键获取值 import java.util.HashMap; import java.util.Set;public class Test {public static void main(String[] args) {HashMap hashMap new HashMap();hashMap.put("语文",99);has…...

理解 MCP 工作流:使用 Ollama 和 LangChain 构建本地 MCP 客户端
🌟 什么是 MCP? 模型控制协议 (MCP) 是一种创新的协议,旨在无缝连接 AI 模型与应用程序。 MCP 是一个开源协议,它标准化了我们的 LLM 应用程序连接所需工具和数据源并与之协作的方式。 可以把它想象成你的 AI 模型 和想要使用它…...
Nginx server_name 配置说明
Nginx 是一个高性能的反向代理和负载均衡服务器,其核心配置之一是 server 块中的 server_name 指令。server_name 决定了 Nginx 如何根据客户端请求的 Host 头匹配对应的虚拟主机(Virtual Host)。 1. 简介 Nginx 使用 server_name 指令来确定…...

从零实现STL哈希容器:unordered_map/unordered_set封装详解
本篇文章是对C学习的STL哈希容器自主实现部分的学习分享 希望也能为你带来些帮助~ 那咱们废话不多说,直接开始吧! 一、源码结构分析 1. SGISTL30实现剖析 // hash_set核心结构 template <class Value, class HashFcn, ...> class hash_set {ty…...
是否存在路径(FIFOBB算法)
题目描述 一个具有 n 个顶点e条边的无向图,该图顶点的编号依次为0到n-1且不存在顶点与自身相连的边。请使用FIFOBB算法编写程序,确定是否存在从顶点 source到顶点 destination的路径。 输入 第一行两个整数,分别表示n 和 e 的值(1…...
今日学习:Spring线程池|并发修改异常|链路丢失|登录续期|VIP过期策略|数值类缓存
文章目录 优雅版线程池ThreadPoolTaskExecutor和ThreadPoolTaskExecutor的装饰器并发修改异常并发修改异常简介实现机制设计原因及意义 使用线程池造成的链路丢失问题线程池导致的链路丢失问题发生原因 常见解决方法更好的解决方法设计精妙之处 登录续期登录续期常见实现方式特…...

使用LangGraph和LangSmith构建多智能体人工智能系统
现在,通过组合几个较小的子智能体来创建一个强大的人工智能智能体正成为一种趋势。但这也带来了一些挑战,比如减少幻觉、管理对话流程、在测试期间留意智能体的工作方式、允许人工介入以及评估其性能。你需要进行大量的反复试验。 在这篇博客〔原作者&a…...
Mysql8 忘记密码重置,以及问题解决
1.使用免密登录 找到配置MySQL文件,我的文件路径是/etc/mysql/my.cnf,有的人的是/etc/mysql/mysql.cnf 在里最后加入 skip-grant-tables重启MySQL服务 service mysql restartShutting down MySQL… SUCCESS! Starting MySQL… SUCCESS! 重启成功 2.登…...

android RelativeLayout布局
<?xml version"1.0" encoding"utf-8"?> <RelativeLayout xmlns:android"http://schemas.android.com/apk/res/android"android:layout_width"match_parent"android:layout_height"match_parent"android:gravity&…...