在同一個文件夾下
成都創(chuàng)新互聯(lián)網(wǎng)站建設公司一直秉承“誠信做人,踏實做事”的原則,不欺瞞客戶,是我們最起碼的底線! 以服務為基礎,以質(zhì)量求生存,以技術求發(fā)展,成交一個客戶多一個朋友!專注中小微企業(yè)官網(wǎng)定制,做網(wǎng)站、網(wǎng)站建設,塑造企業(yè)網(wǎng)絡形象打造互聯(lián)網(wǎng)企業(yè)效應。
調(diào)用函數(shù):
A.py文件:
B.py文件:
或
調(diào)用類:
A.py文件:
B.py文件:
或
在不同文件夾下
A.py文件的文件路徑:E:\PythonProject\winycg
B.py文件:
針對這個問題,網(wǎng)上有很多的解決方式。其實最主要的原因是因為Python無法正確找到你其他文件夾下文件的路徑。針對不同的環(huán)境和問題有不同的方法,大家可自行測試。
方法一
環(huán)境,Python為3.5,pycharm工作區(qū)間。主文件(main_preprocess.py)需要運用split_by_date.py中的函數(shù),main_preprocess與split_by_date在同一個大文件夾下,其中split_by_date在preprocess文件夾下
2.文件夾目錄視圖:
3.以下問題針對的問題如下:
在此處有一個文件???application/app/folder/file.py
想在?application/app2/some_folder/some_file.py? 中應用file.py
方法二
方法三
但是這個方法必須保證folder文件夾(也就是需要的文件夾下)包含__init__.py,若是沒有,可以新建一個
方法四
此法適用于 python3 on linux
方法五
當文件在平行路徑下時,如
application/app2/some_folder/some_file.py
application/app2/another_folder/another_file.py
Python中函數(shù)參數(shù)的傳遞是通過“賦值”來傳遞的。但這條規(guī)則只回答了函數(shù)參數(shù)傳遞的“戰(zhàn)略問題”,并沒有回答“戰(zhàn)術問題”,也就說沒有回答怎么賦值的問題。函數(shù)參數(shù)的使用可以分為兩個方面,一是函數(shù)參數(shù)如何定義,二是函數(shù)在調(diào)用時的參數(shù)如何解析的。而后者又是由前者決定的。函數(shù)參數(shù)的定義有四種形式:
1. F(arg1,arg2,...)
2. F(arg2=value,arg3=value...)
3. F(*arg1)
4. F(**arg1)
第1 種方式是最“傳統(tǒng)”的方式:一個函數(shù)可以定義不限個數(shù)參數(shù),參數(shù)(形式參數(shù))放在跟在函數(shù)名后面的小括號中,各個參數(shù)之間以逗號隔開。用這種方式定義的函數(shù)在調(diào)用的時候也必須在函數(shù)名后的小括號中提供相等個數(shù)的值(實際參數(shù)),不能多也不能少,而且順序還必須相同。也就是說形參和實參的個數(shù)必須一致,而且想給形參1的值必須是實參中的第一位,形參與實參之間是一一對應的關系,即“形參1=實參1 形參2=實參2...”。很明顯這是一種非常不靈活的形式。比如:"def addOn(x,y): return x + y",這里定義的函數(shù)addOn,可以用addOn(1,2)的形式調(diào)用,意味著形參x將取值1,主將取值2。addOn(1,2,3)和addOn (1)都是錯誤的形式。
第2種方式比第1種方式,在定義的時候已經(jīng)給各個形參定義了默認值。因此,在調(diào)用這種函數(shù)時,如果沒有給對應的形式參數(shù)傳遞實參,那么這個形參就將使用默認值。比如:“def addOn(x=3,y=5): return x + y”,那么addOn(6,5)的調(diào)用形式表示形參x取值6,y取值5。此外,addOn(7)這個形式也是可以的,表示形參x取值7,y取默認值5。這時候會出現(xiàn)一個問題,如果想讓x取默認值,用實參給y賦值怎么辦?前面兩種調(diào)用形式明顯就不行了,這時就要用到Python中函數(shù)調(diào)用方法的另一大絕招 ──關健字賦值法??梢杂胊ddOn(y=6),這時表示x取默認值3,而y取值6。這種方式通過指定形式參數(shù)可以實現(xiàn)可以對形式參數(shù)進行“精確攻擊”,一個副帶的功能是可以不必遵守形式參數(shù)的前后順序,比如:addOn(y=4,x=6),這也是可以的。這種通過形式參數(shù)進行定點賦值的方式對于用第1種方式定義的函數(shù)也是適用的。
上面兩種方式定義的形式參數(shù)的個數(shù)都是固定的,比如定義函數(shù)的時候如果定義了5個形參,那么在調(diào)用的時候最多也只能給它傳遞5個實參。但是在實際編程中并不能總是確定一個函數(shù)會有多少個參數(shù)。第3種方式就是用來應對這種情況的。它以一個*加上形參名的方式表示,這個函數(shù)實際參數(shù)是不一定的,可以是零個,也可以是N個。不管是多少個,在函數(shù)內(nèi)部都被存放在以形參名為標識符的tuple中。比如:
對這個函數(shù)的調(diào)用addOn() addOn(2) addOn(3,4,5,6)等等都是可以的。
與第3種方式類似,形參名前面加了兩個*表示,參數(shù)在函數(shù)內(nèi)部將被存放在以形式名為標識符的dictionary中。這時候調(diào)用函數(shù)必須采用key1=value1、key2=value2...的形式。比如:
1. def addOn(**arg):
2. sum = 0
3. if len(arg) == 0: return 0
4. else:
5. for x in arg.itervalues():
6. sum += x
7. return sum
那么對這個函數(shù)的調(diào)用可以用addOn()或諸如addOn(x=4,y=5,k=6)等的方式調(diào)用。
上面說了四種函數(shù)形式定義的方式以及他們的調(diào)用方式,是分開說的,其實這四種方式可以組合在一起形成復雜多樣的形參定義形式。在定義或調(diào)用這種函數(shù)時,要遵循以下規(guī)則:
1. arg=value必須在arg后
2. *arg必須在arg=value后
3. **arg必須在*arg后
在函數(shù)調(diào)用過程中,形參賦值的過程是這樣的:
首先按順序把“arg”這種形式的實參給對應的形參
第二,把“arg=value”這種形式的實參賦值給形式
第三,把多出來的“arg”這種形式的實參組成一個tuple給帶一個星號的形參
第四,把多出來的“key=value”這種形式的實參轉為一個dictionary給帶兩個星號的形參。
例子:
1. def test(x,y=5,*a,**b):
2. print x,y,a,b
就這么一個簡單函數(shù),來看看下面對這個函數(shù)調(diào)用會產(chǎn)生什么結果:
test(1) === 1 5 () {}
test(1,2) === 1 2 () {}
test(1,2,3) === 1 2 (3,) {}
test(1,2,3,4) === 1 2 (3,4)
test(x=1) === 1 5 () {}
test(x=1,y=1) === 1 1 () {}
test(x=1,y=1,a=1) === 1 1 () {'a':1}
test(x=1,y=1,a=1,b=1) === 1 1 () {'a':1,'b':1}
test(1,y=1) === 1 1 () {}
test(1,2,y=1) === 出錯,說y給賦了多個值
test(1,2,3,4,a=1) === 1 2 (3,4) {'a':1}
test(1,2,3,4,k=1,t=2,o=3) === 1 2 (3,4) {'k':1,'t':2,'o':3}
網(wǎng)上的很多資料都是說“如果把my_abs()的函數(shù)定義保存為abstest.py文件了,那么,可以在該文件的當前目錄下啟動Python解釋器,用from abstest import my_abs來導入my_abs()函數(shù),注意abstest是文件名(不含.py擴展名)”。但是在嘗試這種方法后,發(fā)現(xiàn)仍然還是無法調(diào)用自定義的函數(shù)。
python的引外機制:
import abc
1、首先在當前目錄下找有沒有abc、abc.py
2、找python的安裝目錄:F:\Python2.7Exe\Lib\site-packages;F:\Python2.7Exe\Lib;
3、找電腦中path下面的目錄
于是我改變路徑,將保存的abc.py文件直接放在python的安裝目錄下,使用import abc命令,然后在Python交互界面用 abc.XXX(XXX是abc.py文件中的定義函數(shù)的函數(shù)名),解決了調(diào)用自定義函數(shù)問題。
使用字典,比如下面這樣:
def?funcA():
pass
def?funcB():
pass
def?func_None():
print?"cannot?find?func"
func_dict?=?{"a":?funcA,?"b":?funcB}
def?func(x):
return?func_dict.get(x,?func_None)()
在有switch的語言中,一般都是使用switch來根據(jù)入?yún)⑦M行判斷。但是python中沒有switch,因為根本不需要??!使用字典代替switch,性能更高,而且這種方法的表述能力更強一點。
另外func_dict.get(x, func_None)()中方法是從字典中取出值對應的函數(shù)對象,然后后面加上()是執(zhí)行該對象的__call__方法。因為python中函數(shù)就是實現(xiàn)了__call__方法的對象。所以可以這么使用。
將event.py目錄加入到system path中
import?sys
sys.path.append("/Users/songrao/Library/Application?Support/Sublime?Text?3/Packages/User/")
from?event?import?printme
同一個類中一個函數(shù)里調(diào)用另一個函數(shù)的方法
class Solution:
def a(self):
self.b() # 注意這種寫法:self.類名
def b(self):
print('在這里')
a = Solution()
a.a()