如何在 Python 中调用不同模块中的函数而不重复该函数

Posted

技术标签:

【中文标题】如何在 Python 中调用不同模块中的函数而不重复该函数【英文标题】:How to call a function in a different module in Python and not repeating the function 【发布时间】:2021-09-18 15:00:06 【问题描述】:

我在 Python 的不同页面中定义了一个函数,如下所示:

def getData():
    user=input('Enter Name')
    if user=='Irfan':
        mydb = mysql.connector.connect(host='localhost', user='root', passwd='', database='sample_data')
        df = pd.read_sql_query('select * from sample_data.sample_data3', mydb)
    else:
        if user=='Usman':
            mydb = mysql.connector.connect(host='localhost', user='root', passwd='', database='')
            df = pd.read_sql_query('select * from sample_data.sample_data1', mydb)

    return df

但是,由于该函数在项目的许多其他文件中被调用,它在运行时一遍又一遍地要求我输入用户名。

如何输入用户名一次,然后使用该缓存值获取所需的数据库,而无需多次输入用户名?

(对不起,用外行的话问;我是初学者。)

【问题讨论】:

【参考方案1】:

怎么样:


user = ''
def getData():
    if len(user) == 0:
        user=input('Enter Name')
    
    if user=='Irfan':
        mydb = mysql.connector.connect(host='localhost', user='root', passwd='', database='sample_data')
        df = pd.read_sql_query('select * from sample_data.sample_data3', mydb)
    else:
        if user=='Usman':
            mydb = mysql.connector.connect(host='localhost', user='root', passwd='', database='')
            df = pd.read_sql_query('select * from sample_data.sample_data1', mydb)

    return df

通过将用户变量放在函数之外,它就变成了一个全局变量。在您测试内部,用户变量是否已填充

【讨论】:

【参考方案2】:

您可以获取一次用户输入并将名称作为参数传递给您的函数,如下所示:

user = input('Enter name')
def getData(user):
    ##your code
    

【讨论】:

【参考方案3】:

使凭据全局化..

user=input('Enter Name')

def getData():
global user
if user=='Irfan':
    mydb = mysql.connector.connect(host='localhost', user='root', passwd='', database='sample_data')
    df = pd.read_sql_query('select * from sample_data.sample_data3', mydb)
else:
    if user=='Usman':
        mydb = mysql.connector.connect(host='localhost', user='root', passwd='', database='')
        df = pd.read_sql_query('select * from sample_data.sample_data1', mydb)

return df

【讨论】:

以上是关于如何在 Python 中调用不同模块中的函数而不重复该函数的主要内容,如果未能解决你的问题,请参考以下文章

apache中的vhost重写规则-摆脱子域而不重定向

我想在提交时创建一个表而不重定向到 php 中的任何其他页面

如何使用 python 多线程并行化来自另一个模块的函数而不进行酸洗?

ExtJS:重新加载数据存储而不重绘网格

使用重载的 PySide 信号调用 Python 函数而不传递参数

替换/操作 url 中的“主机名”而不重定向到它