python對象獲取類
A. 如何理解python的類與對象
問的太籠統了,不知道答的對不對. 看下面的圖
左邊元類,中間類,右邊實例
其實記住的只是一點:python里一切都是對象,實例是對象,類是對象,元類也是對象.
這里題主說的類和對象其實是包含和被包含的關系了.
那麼Python里的類和其他的對象有什麼區別?
實例是對象,因為創建實例的是類.類是對象,創建類的是什麼呢?Python給的答案就是元類.你可以通過type()函數來查看它的元類.(type(type)得到的是它自己)
其實這個類和其他對象一樣,所以我們就不驚訝它為什麼有類方法,類變數了..
B. python中類對象的理解總結
9.3.2. 類對象
類對象支持兩種操作:屬性引用和實例化。
屬性引用 使用和 Python 中所有的屬性引用一樣的標准語法:obj.name。類對象創建後,類命名空間中所有的命名都是有效屬性名。所以如果類定義是這樣:
class MyClass:
"""A simple example class"""
i = 12345
def f(self):
return 'hello world'
那麼 MyClass.i 和 MyClass.f 是有效的屬性引用,分別返回一個整數和一個方法對象。也可以對類屬性賦值,你可以通過給 MyClass.i 賦值來修改它。 __doc__ 也是一個有效的屬性,返回類的文檔字元串:"A simple example class"。
類的 實例化 使用函數符號。只要將類對象看作是一個返回新的類實例的無參數函數即可。例如(假設沿用前面的類):
x = MyClass()
以上創建了一個新的類 實例 並將該對象賦給局部變數 x。
這個實例化操作(「調用」一個類對象)來創建一個空的對象。很多類都傾向於將對象創建為有初始狀態的。因此類可能會定義一個名為 __init__() 的特殊方法,像下面這樣:
def __init__(self):
self.data = []
類定義了 __init__() 方法的話,類的實例化操作會自動為新創建的類實例調用 __init__() 方法。所以在下例中,可以這樣創建一個新的實例:
x = MyClass()
當然,出於彈性的需要,__init__() 方法可以有參數。事實上,參數通過 __init__() 傳遞到類的實例化操作上。例如,
>>> class Complex:
... def __init__(self, realpart, imagpart):
... self.r = realpart
... self.i = imagpart
...
>>> x = Complex(3.0, -4.5)
>>> x.r, x.i
(3.0, -4.5)
C. python 如何得到類的所有實例
importgc
classDog(object):
def__init__(self,name):
self.name=name
dahuang=Dog('1')
xiao=Dog('2')
forobjingc.get_objects():
ifisinstance(obj,Dog):
printobj.name
D. python 獲取列表元素有幾種方式,常見的是哪種
Python中列表常見的方法有哪些?
Python列表定義:按特定順序排列的元素組成。在Python中,用方括弧[]來表示列表,並用逗號來分隔其中的元素。Python列表是編程中很常見的數據類型 。
列表是一種可修改的集合類型,其元素可以是數字、string等基本類型,也可以是列表、元組、字典等集合對象,甚至可以是自定義的類型。其定義方式如下:>>> nums = [1,2,3,4]>>> type(nums)>>> print nums[1, 2, 3, 4]>>> strs = ["hello","world"]>>> print strs['hello', 'world']>>> lst = [1,"hello",False,nums,strs]>>> type(lst)>>> print lst[1, 'hello', False, [1, 2, 3, 4], ['hello', 'world']]
下面我們來看一下列表中有哪些常見的方法:count():統計某個元素在列表中出現的次數。index():從列表中找出某個值第一個匹配項的索引位置。append():在列表末尾添加新對象。extend():在列表末尾一次性追加另一個序列的多個值。insert():在列表的指定位置插入對象。pop():移除列表中的一個元素(默認最後一個元素),並且返回該元素的值。remove():移除列表中某個值的第一個匹配項。reverse():將列表中的元素反向,不重新拷貝一個列表。reversed():將列表中的元素反向,重新拷貝一個列表。sort():將列表中的元素排序,不重新拷貝一個列表。sortd():將列表中的元素排序,重新拷貝一個列表。():淺拷貝,只是給原來的列表貼上了一個新標簽,對於一個復雜對象的子對象並不會完全復制,如果有子列表,改變原來的值,新的拷貝對象也會改變。deep():深拷貝,將復雜對象的每一層復制一個單獨的個體出來。就是完全拷貝。常見內置函數:max()、min()、sum()、len()、all()、any()、zip()、enumerate()由於文章篇幅有限,具體的代碼,推薦大家看這篇文章:https://www.jianshu.com/p/da6e449f4c6a
E. python什麼是類,對象,實例
類和對象
對象是什麼?
對象=屬性(靜態)+方法(動態);
屬性一般是一個個變數;方法是一個個函數;
#類的屬性 就是 類變數
#實例變數:定義在方法中的變數,只作用於當前實例的類。
例子:
class Turtle:#python 中類名約定以大寫字母開頭
'''關於類的簡單例子。。。'''
#屬性 == 類變數
color ="green"
weight="10kg"
legs=4
shell=True
mouth='big'
#方法
def climb(self):
self.name = "test" #實例變數:定義在方法中的變數,只作用於當前實例的類。
print("我在很努力爬。")
def run(self):
print('我在很努力跑。')
def bite(self):
print('我要要要要要')
def sleep(self):
print('我要睡覺啦。')
#創建一個實例對象也就是類的實例化!
tt =Turtle() #類的實例化,也就是創建一個對象,類名約定大寫字母開頭
tt.bite() #創建好類後就能調用類裡面的方法叻;
tt.sleep()
F. python 中有關對象和類還有self,沒有理解
self
就是類中的,指的就是你的那個類的名稱,如果一個變數以self.開頭,說明這個變數是全局的,並且當你在這個類外面的時,可直接用類名稱.(self.後面的)表示
G. python類的定義與使用是什麼
類Class:用來描述具體相同的屬性和方法的對象的集合。定義了該集合中每個對象所共有的屬性和方法。對象是類的示例。
類定義完成時(正常退出),就創建了一個 類對象。基本上它是對類定義創建的命名空間進行了一個包裝;我們在下一節進一步學習類對象的知識。原始的局部作用域(類定義引入之前生效的那個)得到恢復,類對象在這里綁定到類定義頭部的類名(例子中是 ClassName )。
基本語法
Python的設計目標之一是讓代碼具備高度的可閱讀性。它設計時盡量使用其它語言經常使用的標點符號和英文單字,讓代碼看起來整潔美觀。它不像其他的靜態語言如C、Pascal那樣需要重復書寫聲明語句,也不像它們的語法那樣經常有特殊情況和意外。
以上內容參考:網路-Python
H. python 為什麼實例對象可以調用類方法
實例是什麼?實例是類定義的實體化。那麼,類中所定義的屬性、方法,只要沒有被屏蔽,在它的實體中就同樣是可訪問的。
至於說沒有run()沒有參數self,而是參數cls,為什麼可用,那就是裝飾器@classmethod在起作用了,理解了裝飾器,就知道這個問題的答案了。不然的話,還有@staticmethod可以讓方法連cls方法都不需要又怎麼說。
I. 如何獲取一個對象obj 的類型 python
內置type函數就可以返回對象的類型
type('hello')
#str
type(123)
#int
J. 用Python的類與對象
class Student():
def __init__(self,name,age,score):
self.name = name
self.age = age
self.score = score
def get_name(self):
return self.name
def get_age(self):
return self.age
def get_course(self):
return max(self.score)
st = Student('張三', 20, [150, 88, 100])
print(st.get_name())
print(st.get_age())
print(st.get_course())