index()方法:用於從列表中找出某個值第一個匹配項的索引位置。
語法:listname.index(x,start,end)
如:list.index('python')
返回的結果是list列表
中python
這個元素對應的索引值。
①、append()方法:用於在列表的末尾追加元素
語法:listname.append(x)
②、extend()方法:用於在列表的末尾追加元素
語法:listname.extend([x])
③、insert()方法:用於在列表中間某個位置插入元素
語法:listname.insert(index, x)
④、合並方法:利用列表的切片操作,將兩個列表進行合並。
①、def方法:根據索引值刪除元素
語法:def listname[index]
或 del listname[start, end]
②、pop()方法:根據索引值刪除元素
語法:listname.pop(index)
③、remove()方法:根據元素值刪除元素
語法:listname.remove(x)
④、clear()方法:清空列表
語法:listname.clear()
①、sort()方法
語法:listname.sort(reverse=)
②、sorted()方法
語法:sorted(listname, reverse= )
③、兩種方法的區別
sort()方法是在原列表的基礎上,直接排序,會改變原列表;
sorted()方法會將排序結果保留到新的列表中,原列表不會改變。
''' 舉一個例子,將偶數篩選出來,放到一個列表裡,打印這個列表 '''
# 一般的寫法
li1 = []
for i in range(1, 10):
if i % 2 == 0:
li1.append(i)
print('一般寫法的輸出結果:', li1)
# 列表生成式的寫法
li2 = [i for i in range(1, 10) if i % 2 == 0]
print('列表生成式的輸出結果:', li2)
結果如下:
一般寫法的輸出結果: [2, 4, 6, 8]
列表生成式的輸出結果: [2, 4, 6, 8]
①、[ ]方法
語法:dictname["key"]
②、get()方法
語法:dictname.get("key")
③、兩種方法的區別
[ ]方法,找不到對應的key,會報一個KeyError錯誤;
get方法,找不到對應的key,會返回None,也可以通過參數設置,使返回值不是None,而是設定的值。
如:
result = dictname.get("key", 'error')
如果key不是dictname字典中存在的鍵,那麼打印result的結果是error。
①、[ ]方法
語法:dictname[key] = value
②、update()方法
語法1:dictname.update({key : value})
語法2:dictname.update(key = value)
①、pop()方法
語法:dictname.pop(key)
②、del方法
語法:del dictname[key]
③、clear()方法:用於清空字典
語法:dictname.clear()
keys = dictname.keys() # 獲取所有key組成的視圖
values = dictname.values() # 獲取所有value組成的視圖
items = dictname.items() # 獲取所有key-value對,組成的視圖
示例如下:
''' 將字典的key與value位置互換 '''
dict1 = {
"one": 1, "two": 2, "three": 3}
dict2 = {
value: key for key, value in dict1.items()}
print(dict2)
輸出結果:
{
1: 'one', 2: 'two', 3: 'three'}
①、add()方法:一次添加一個元素
語法:setname.add(x)
②、update()方法:一次添加多個元素
語法:setname.update(x)
示例如下:
a = set('str')
a.add('python')
b = set('str')
b.update('python')
c = {
1, 2, 3}
c.add(80)
d = {
1, 2, 3}
d.update([10, 20, 30])
''' d.update([10, 20, 30]) 也可以寫成 d.update({10, 20, 30}) d.update((10, 20, 30)) '''
print(a)
print(b)
print(c)
print(d)
輸出結果:
{
'python', 't', 'r', 's'}
{
'n', 'r', 'h', 'o', 'y', 'p', 's', 't'}
{
80, 1, 2, 3}
{
1, 2, 3, 10, 20, 30}
①、remove()方法:刪除指定元素
語法:setname.remove(element)
②、discard()方法:刪除指定元素
語法:setname.discard(element)
remove()方法和discard()方法的區別:
使用 remove 方法刪除元素時,如果元素不存在集合中,那麼程序會報錯。
使用 discard 方法刪除元素時,如果元素不存在集合中,那麼程序不會報錯。
③、pop()方法:刪除第一個元素,並返回刪除的元素
語法:setname.pop()
④、clear()方法:清空集合
語法:setname.clear()
示例如下:
a = {
1, 2, 3, 4, 5}
a.remove(2)
print(a)
b = {
1, 2, 3, 4, 5}
b.discard(3)
print(b)
c1 = {
1, 2, 3, 4, 5}
c2 = c1.pop()
print(c1)
print(c2)
d = {
1, 2, 3, 4, 5}
d.clear()
print(d)
輸出結果:
{
1, 3, 4, 5}
{
1, 2, 4, 5}
{
2, 3, 4, 5}
1
set()
相比與列表生成式,只是將 [ ] 改成了 { } ;
如果你想去除重復的元素,可以使用集合生成式。
split()方法:指定分隔符對字符串進行切片
語法:strname.split(x)
replace()方法:把字符串中的舊字符串替換成新字符串
語法:strname.replace(old, new)
①、+ 方法
通過+這個符號來拼接字符串
②、join()方法:將列表(或元組)中多個字符串采用固定的分隔符連接在一起
語法:newstr = str.join(iterable)
lie = ['www', 'baidu', 'com']
newstr = '.'.join(lie)
print(newstr)
輸出結果:
www.baidu.com
try:
# 這部分寫不能確定正確執行的代碼
except Exception as e:
print('未知錯誤 %s' %e)
定義類的基本語法如下:
class 類名:
多個(≥0)類屬性...
多個(≥0)類方法...
類體中、所有函數之外:此范圍定義的變量,稱為類屬性或類變量;
類體中,所有函數之內:以“self.變量名”的方式定義的變量,稱為實例屬性或實例變量;
class Person():
introduce = "大家好!" # 類屬性
def __init__(self, name, age):
self.name = name # 實例屬性
self.age = age # 實例屬性
不用任何修改的方法為實例方法;
采用 @classmethod 修飾的方法為類方法;
采用 @staticmethod 修飾的方法為靜態方法。
class Person():
def say(self):
print("正在調用實例方法")
@classmethod
def eat(cls):
print("正在調用類方法")
@staticmethod
def drink():
print("正在調用靜態方法")
class Person():
def say(self): # 實例方法
print("我是張三")
zhang = Person() # 創建類對象,zhang
""" 類對象調用實例方法的兩種方式: 1、通過類對象名調用實例方法 2、通過類名直接調用實例方法 """
zhang.say()
Person.say(zhang)
如果類中的變量和函數,其名稱以雙下劃線“__”開頭,則該變量(函數)為私有變量(私有函數),從而實現類的封裝。
參考:
https://blog.csdn.net/sinat_38682860/article/details/109560354
實現繼承的類稱為子類,被繼承的類稱為父類(也可稱為基類、超類)。
子類繼承父類時,只需在定義子類時,將父類(可以是多個)放在子類之後的圓括號裡即可。語法格式如下:
(具有多個父類,即為多繼承)
class 類名(父類1, 父類2, ...):
#類定義部分
注意:如果該類沒有顯式指定繼承自哪個類,則默認繼承 object 類。
(object 類是 Python 中所有類的父類,即要麼是直接父類,要麼是間接父類)
class People:
def say(self):
print("我是一個人,名字是:",self.name)
class Animal:
def display(self):
print("人也是高級動物")
#同時繼承 People 和 Animal 類
#其同時擁有 name 屬性、say() 和 display() 方法
class Person(People, Animal):
pass
zhangsan = Person()
zhangsan.name = "張三"
zhangsan.say()
zhangsan.display()
有繼承,就要有重寫。重寫指的是對類中已有方法的內部實現進行修改。
class Bird:
#鳥有翅膀
def isWing(self):
print("鳥有翅膀")
#鳥會飛
def fly(self):
print("鳥會飛")
class Ostrich(Bird):
# 重寫Bird類的fly()方法
def fly(self):
print("鴕鳥不會飛")
# 創建Ostrich對象
ostrich = Ostrich()
# 調用被重寫的方法
ostrich.fly()
# 調用 Bird 類中的 fly() 方法 || 調用未被重寫的方法
Bird.fly(ostrich)
在子類中的構造方法中,調用父類構造方法的方式:使用 super() 函數。但如果涉及多繼承,該函數只能調用第一個直接父類的構造方法。
class People:
def __init__(self, name):
self.name = name
def say(self):
print("我是人,名字為:", self.name)
class Animal:
def __init__(self, food):
self.food = food
def display(self):
print("我是動物,我吃", self.food)
class Person(People, Animal):
# 自定義構造方法
def __init__(self, name, food):
# 調用 People 類的構造方法
super().__init__(name)
# super(Person,self).__init__(name) #執行效果和上一行相同
# People.__init__(self,name)#使用未綁定方法調用 People 類構造方法
# 調用其它父類的構造方法,需手動給 self 傳值
Animal.__init__(self, food)
per = Person("zhangsan", "熟食")
per.say()
per.display()
類的多態特性的前提條件:
class CLanguage:
def say(self):
print("調用的是 Clanguage 類的say方法")
class CPython(CLanguage):
def say(self):
print("調用的是 CPython 類的say方法")
class CLinux(CLanguage):
def say(self):
print("調用的是 CLinux 類的say方法")
a = CLanguage()
a.say()
a = CPython()
a.say()
a = CLinux()
a.say()
Python 這種由多態衍生出的更靈活的編程機制,被稱為“鴨子模型”或“鴨子類型”。例子如下:
class WhoSay:
def say(self,who):
who.say()
class CLanguage:
def say(self):
print("調用的是 Clanguage 類的say方法")
class CPython(CLanguage):
def say(self):
print("調用的是 CPython 類的say方法")
class CLinux(CLanguage):
def say(self):
print("調用的是 CLinux 類的say方法")
a = WhoSay()
#調用 CLanguage 類的 say() 方法
a.say(CLanguage())
#調用 CPython 類的 say() 方法
a.say(CPython())
#調用 CLinux 類的 say() 方法
a.say(CLinux())
此程序中,通過給 WhoSay 類中的 say() 函數添加一個 who 參數,其內部利用傳入的 who 調用 say() 方法。這意味著,當調用 WhoSay 類中的 say() 方法時,我們傳給 who 參數的是哪個類的實例對象,它就會調用那個類中的 say() 方法。