python - 關(guān)于函數(shù)調(diào)用的問題
問題描述
def test1(): a = 1 b = 2 def test2(): c = 3 d = c + a print(d)test2這邊想實現(xiàn)下面的test2調(diào)用上面test1里面的數(shù)據(jù),要怎么實現(xiàn),使用的是python3
問題解答
回答1:首先,你這種需求是不可能且不合理的,兩個分立的函數(shù)不可能相互訪問里面的變量的
如果用閉包倒是可以做到,不過不知道是不是你想要的:
def test1(): a = 1 b = 2 def test2():c = 3d = c + aprint(d) return test2test2 = test1()test2()回答2:
可以將test1封裝為一個類
#-*-coding:utf8-*-class test1(): '''docstring for test1''' def __init__(self):self.a=0self.b=0self.test1() def test1(self):self.a=1self.b=2test = test1()def test2(): c=3 d=c+test.a print (d)test2()
初始化可以放在你想調(diào)用的位置,并且在初始化的時候默認調(diào)用了test1()方法,這樣就可以通過類的對象訪問數(shù)據(jù)了。
回答3:可以讓test1用return來返回a和b的值:
def test1(): a = 1 b = 2 return a,bdef test2(): c = 3 a,b = test1() d = c + a print(d)test2()回答4:
哈哈,都是人才,閉包、封類、明確返回,以上每一個都是獨立的解決辦法。
相關(guān)文章:
1. pip安裝提示Twisted錯誤問題(Python3.6.4安裝Twisted錯誤)2. javascript - vue-echarts-v3使用的過程中折線圖區(qū)域呈漸變色。3. 關(guān)于Mysql聯(lián)合查詢4. centos7 編譯安裝 Python 3.5.1 失敗5. mysql - 這個數(shù)據(jù)庫合計用 視圖做,和直接算好存在數(shù)據(jù)庫里,到時候調(diào)用起來哪個快?6. python - beautifulsoup獲取網(wǎng)頁內(nèi)容的問題7. python - 能通過CAN控制一部普通的家用轎車嗎?8. 人工智能 - python 機器學習 醫(yī)療數(shù)據(jù) 怎么學9. mysql - 分庫分表、分區(qū)、讀寫分離 這些都是用在什么場景下 ,會帶來哪些效率或者其他方面的好處10. c++ - 請問MySQL_Connection::isReadOnly 怎么解決?
