① pandas中為什麼引用series函數會報錯,說沒有被定義
可以截圖看看,一般不會這樣
一般流程是:
import pandas as pd
A = pd.Series([1,2])
print(A)
② python這哪沒有給他定義呢
就是沒有定義,定義的語句,你寫的是 "." ,點是對象的操作
③ python 形參沒有被定義感覺遇到鬼了。。。
一、前言
在python中,函數參數的定義和傳遞有以下幾種方式:
語法
意義
def func(name)
普通參數,可以根據位置匹配,也可以根據key來匹配
def func(name=value)
默認參數,當參數沒有傳遞時,使用默認值
def func(*iteratable)
將所有剩下的未匹配的參數收集至一個tuple中
def func(**dictionary)
將剩下未匹配的參數收集值一個dict中
def func(*, name)
必須使用key來匹配參數
def func(*other, name)
必須使用key來匹配參數
func(value)
函數調用,參數值按傳遞的參數順序匹配
func(name=value)
函數調用,參數值根據key來匹配
func(*iteratable)
函數調用,將iteratable容器中的參數展開,按位置匹配對應的函數參數
func(**dictionary)
函數調用,將dict中的參數展開,按key值來匹配對應的函數參數
在python中,參數可以按照順序傳遞,在調用函數時,參數的值按照傳遞的順序,從左到右依次匹配。並且還可以給參數傳遞默認值,這都很好理解,因為在C、C++、Java等許多語言中,函數的參數傳遞都是按照這種方法來傳遞的。
但python的參數定義和傳遞除了按照順序傳遞以及可以給默認值外,它還有其它的一些特點,在進一步講解之前,首先說明python中函數調用中參數匹配的順序:
按照順序,給沒有key的參數賦值,意味著傳遞參數時,需按順序匹配的參數必須出現在按key匹配的參數之前;
給按照key匹配的參數賦值;
將多餘的按照順序匹配但未匹配的參數值歸入*name的tuple中;
將多餘未匹配上的按照key進行匹配的參數值歸入**name的dict對象中;
將為匹配上的且具有默認值的參數賦默認值
二、按key匹配參數
對於C、C++這種語言,在調用函數時,系統會首先將函數地址壓入堆棧,其次按參數的從右往左的順序,一次壓入堆棧。因此,C、C++這種語言它們只支持按順序匹配形參。而python的做法不同,參數除了可以按順序匹配,還可以按照參數名稱來匹配。如:
def func(name, age):
print(name, age)
對於這個函數,以下的調用時等價的:
func('rechar', 27) #按順序匹配
func(name = 'rechar', age = 27) #按參數名稱匹配,在運行時告訴系統參數name的值為『rechar』,age的值為27
func(age = 27, name = 'rechar') #按參數名稱匹配
func('rechar', age = 27) #name是按順序匹配,age按名稱匹配
在python中,當按照參數名稱進行匹配參數是,參數傳遞的順序是可以任意的,不要求按照函數定義中參數的順序進行傳遞。在使用名稱匹配時,如果需要混合使用按順序匹配規則,則按順序匹配的參數必須出現在按key匹配的參數前,否則會報錯:
func(name = 'rechar', 27)
以上調用會報如下錯誤:
三、函數定義中的」*name「
python在給按順序匹配和按key匹配的參數賦完值後,如果發現調用者傳入的參數仍有未匹配上的會發生什麼情況呢?看一下下面的例子:
func('rechar', 27, 32)
運行時我們看到如下錯誤:
Traceback (most recent call last):
File "E: mp t.py", line 5, in <mole>
func('rechar', 27, 32)
TypeError: func() takes 2 positional arguments but 3 were given
哦,python會抱怨我們傳遞的參數太多了。那如果確實在一些情況下,我們無法保證傳遞的參數數量一定和函數需要的參數數相等怎麼辦呢?這是就是*iterable這種參數該登場的時候了,假如在定義函數定義是,我們增加了一個參數,這個參數以一個」*「開始,那麼這個參數實際上是一個tuple類型。假如傳遞的參數比需要的多,那那些多餘的參數會被放入這個tuple中。例如,
def func(name, age, *other):
print(name, age, other)
那麼,
func('rechar', 27, 32)
這個調用的輸出如下:
>>> rechar 27 (32,)
四、函數定義中的」**name「
python在將所有未匹配上的非按名稱匹配的參數裝入參數中的tuple之後,假如還有未匹配上的按名稱匹配的參數那情況會怎樣呢?首先來看一下下面的示例:
def func(name, age):
print(name, age)
func(name = 'rechar', age = 27, pay='1800')
執行時,python又抱怨了:
Traceback (most recent call last):
File "E: mp t.py", line 5, in <mole>
func(name = 'rechar', age = 27, pay='1800')
TypeError: func() got an unexpected keyword argument 'pay'
它說func這個函數沒有名稱為」pay「的參數,這種情況或許出現在我們函數重構之後,原來函數時有這個參數的。而這個函數調用可能在別處沒有被修改。假設即使給了」pay「這個參數,程序的正確性不受影響,沒錯,這就是」**name「參數的用武之地了。
假如在函數定義中,給函數增加一個以」**「開頭的參數,那麼這個參數實際上是一個dict對象,它會將參數調用中所有沒有被匹配的按名稱傳遞的參數都放入這個dict中。例如,
def func(name, age,**other):
print(name, age, other)
func(name = 'rechar', age = 27, pay='1800')
那麼運行結果輸出,
rechar 27 {'pay': '1800'}
看到了吧,這里的other就將沒有匹配的」pay=『1800』「收入囊中了。
五、規定調用必須按名稱匹配
當我們在定義函數時,如果第一個參數就是」*name「參數,那麼可想而知,我們無法使用按順序匹配的方式傳遞,因為所有的按順序傳遞的參數值最終的歸宿都會是這里的tuple當中。而為了給後續的參數傳遞值,我們只能使用按名稱匹配的方法。
六、」**「參數只能出現在最後一個形參之後
想想為什麼?其實很好理解,因為出現在」**「形參之後的形參,無論使用按順序傳遞還是按名稱傳遞,最終都無法到達參數值真正應該需要到的地方。所以python規定,如果需要」**「參數,那它必須是最後一個形參。否則python會報語法錯誤。
七、函數調用中的」*「
在表格中我們看到了有func(*iteratable)的調用,這個調用的意思是,iteratable必須是一個可迭代的容器,比如list、tuple;作為參數傳遞值,它最終傳遞到函數時,不是以一個整體出現,而是將其中的元素按照順序傳遞的方式,一次賦值給函數的形參。例如,
li = ['rechar', 27]
func(*li)
這個函數調用與
func('rechar', 27)
是等價的。
八、函數調用中的」**「
知道」*「在函數調用中的效果之後,也就很好理解」**「的作用了。它是將傳遞進來的dict對象分解,每一個元素對應一個按名稱傳遞的參數,根據其中的key對參數進行賦值。
④ python 報錯 類名沒有被定義
python引用xxx.py文件如果使用語句"import xxx",那麼對於此文件中的a類,要用xxx.a表示。如果想直接使用,需要用"from xxx import a"特別引用xxx模塊中的a類,或者"from xxx import *"引用xxx模塊中一切可被引用的東西。
比如你這里要寫成 b = czhhbp.OthelloState(),或者用from導入法省略模塊名
⑤ 定一個一個python函數,ui_hello.show()沒有被定義應該怎麼辦
在另一個Python函數的過程中,你可以去根據它的裡面的函數定義域,如果沒有定義的話,那麼你可以先假設一個定義域,然後在求解的過程中就可以了。
⑥ python報錯沒有定義的變數,為什麼
原則上是不用聲明,但是你放到循環語句裡面,你如果沒有初始化,那麼循環如何判斷呢。
python函數裡面默認是不使用全局變數的,因此你的循環裡面的i仍然是局部變數,這樣的話就沒有初始化,如果使用定義在函數外邊的全局變數,你需要再i = 0 的位置換成global i就可以了。
⑦ python 類裡面的函數總是報錯顯示沒有定義
buildMatrix類TSP中的函數,所以在類內部調用的話,需要加上self. ,否則會被當成外部函數,所以提示未定義
⑧ Python詞頻統計代碼正確但是一直報錯說沒有定義·是什麼意思
請不要這樣說,環境正常的前提下,只要是不能正確運行,都說明代碼有問題