繁体   English   中英

Python:在导入的模块中构造模块变量的最佳方法

[英]Python: Best way to structure module variables in imported module

假设我在numbers.csv文件中有一个参考编号列表。

我正在编写一个模块checker.py ,可以将其导入并调用以检查像这样的数字:

import checker
checker.check_number(1234)

checker.py将加载一个数字列表,并提供check_number来检查列表中是否有给定的数字。 默认情况下,它应该从numbers.csv加载数据,尽管可以指定路径:

DATA_FILEPATH = 'numbers.csv'

def load_data(data_filepath=DATA_FILEPATH):
    ...

REF_LIST = load_data()  

def check_number(num, ref_list=REF_LIST):
    ...

问题-变量和函数的交错对我来说似乎很奇怪。 有没有比上述更好的方法来构造checker.py

我阅读了有关如何在Python中创建模块范围的变量的出色答案

最佳做法是:

  • 声明我在上面完成的REF_LIST列表?

  • 创建一个类似VARS = {'REF_LIST': None}的字典,并在load_data设置VARS['REF_LIST']

  • 创建一个普通的类,并分配clas.REF_LISTload_data

  • 还是取决于情况? (在什么情况下我会使用哪种?)

注意

以前,我通过仅在调用模块中需要时才加载数据来避免这种情况。 因此在checker.py

DATA_FILEPATH = 'numbers.csv'

def load_data(data_filepath=DATA_FILEPATH):
    ...

def check_number(num, ref_list):
    ...

在调用模块中:

import checker
ref_list = checker.load_data()
checker.check_number(1234, ref_list)

但这对我来说加载到调用模块中并不是很有意义,因为如果我想检查5个不同模块中的数字,则需要将load_data 5次。

您可以借助Pandas框架轻松加载csv数据

import pandas as pd
dataframe=pd.read_csv('numbers.csv')

使用以下代码检查datframe中是否存在数字:

numbers=[1,3,8]
for number in numbers:
    if number in dataframe[dataframe.columns[0]]:
        print True
    else:
        print False

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM