成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

Python 初學者容易踩的五個坑

開發 前端
在 Python 中,大多數函數或方法都會返回一個值。比如說我們要對一個列表里面的內容進行排序,可以使用 sorted() 方法。

哈嘍大家好,我是咸魚。

今天咸魚列出了一些大家在初學 Python 的時候容易踩的一些坑,看看你有沒有中招過。

參考文章:https://www.bitecode.dev/p/unexpected-python-traps-for-beginners

不明顯的字符串拼接

Python 在詞法分析的時候會把多個字符串自動拼接起來。

data = "very""lazy"
print(data) # verylazy

這個特性可以讓我們在聲明一個長字符串的時候可以分成多行來寫,這樣看起來比較優雅。

msg = (
    "I want this to be on a single line when it prints " 
    "but I want it to be broken into several lines in "
    "the code"
    )


print(msg)
# I want this to be on a single line when it prints but I want it to be broken into several lines in the code
msg ="I want this to be on a single line when it prints " \
    "but I want it to be broken into several lines in " \
    "the code"

print(msg)
# I want this to be on a single line when it prints but I want it to be broken into several lines in the code

但初學者往往會忽略這一點,他們在使用包含字符串的列表時把分隔符漏掉,造成了意想不到的字符串拼接。

比如說想要聲明一個包含域名的列表host。

host = [
    "localhost",
    "bitecode.dev",
    "www.bitecode.dev"
]

print(host) # ['localhost', 'bitecode.dev', 'www.bitecode.dev']

但是寫成了下面這樣。

host = [
    "localhost",
    "127.0.0.1",
    "bitecode.dev" # 這里把逗號忘掉了
    "www.bitecode.dev"
]

print(host) # ['localhost', 'bitecode.devwww.bitecode.dev']

這是有效的代碼,不會觸發語法錯誤,但是解析的時候會把 "bitecode.dev" 和 "www.bitecode.dev" 拼接在一起,變成 'bitecode.devwww.bitecode.dev' 。

sorted() 和 .sort() 傻傻分不清

在 Python 中,大多數函數或方法都會返回一個值。比如說我們要對一個列表里面的內容進行排序,可以使用 sorted() 方法。

# sorted() 方法會返回一個排序后的新列表
numbers = [4, 2, 3]
sorted_numbers = sorted(numbers)
print(sorted_numbers) # [2, 3, 4]

我們也可以用列表自帶的 .sort() 方法來排序,需要注意的是:.sort() 直接對原有列表進行排序,不會返回任何值。

# .sort() 方法直接對原列表進行排序
numbers = [4, 2, 3]
numbers.sort()
print(numbers) # [2, 3, 4]

但是初學者很容易把 sorted() 的用法用在 .sort() 上,結果發現怎么返回了一個 None。

numbers = [4, 2, 3]
sorted_numbers = numbers.sort()
print(sorted_numbers) # None

list.sort() 修改原列表,它不會返回任何內容。當 Python 可調用對象不返回任何內容時,會得到 None 。

或者把 .sort()  的用法用在了 sorted() 上。

numbers = [4, 2, 3]
sorted(numbers)
print(numbers) # [4, 2, 3]

不要亂加尾隨逗號

我們在創建一個空元組的時候可以用下面的兩種方法:

t1 = ()
t2 = tuple()
print(type(t1))
print(type(t2))

在 Python 中,雖然元組通常都是使用一對小括號將元素包圍起來的,但是小括號不是必須的,只要將各元素用逗號隔開,Python 就會將其視為元組。

t1 = 1,
print(t1) # (1,)
print(type(t1)) # <class 'tuple'>

所以如果在數據后面多加了一個逗號,就會產生一些問題。

比如說下面是一個列表:

colors = [
    'red',
    'blue',
    'green',
]
print(colors) # ['red', 'blue', 'green']

如果不小心加了一個尾隨逗號,列表就變成了元組。

colors = [
    'red',
    'blue',
    'green',
],
print(colors) # (['red', 'blue', 'green'],)

在 python 中,包含一個元素的元組必須有逗號,比如下面是包含一個列表的元組:

colors = [
    'red',
    'blue',
    'green',
],

這是列表:

colors = ([
    'red',
    'blue',
    'green',
])

可怕的 is

在 python 中, is 和 == 都是用來比較 python 對象的,區別是:

  • is 比較需要對象的值和內存地址都相等
  • == 比較只需要對象的值相等就行了

事實上,這兩者的實際使用要遠遠復雜得多。

比如說下面的 a 和 b 是兩個不同的對象,a is b 應該返回 False,但是卻返回了 True

a = 4
b = 4

print(a == b) # True
print(a is b) # True

在 python 中,由于小整數池和緩存機制,使用 is 來比較對象往往會出現意想不到的結果。

關于小整數池和緩存機制可以看我這篇文章:《Python 中 is 和 == 的區別》

奇怪的引用

在Python中,如果 * 運算符用于數字與非數字型數據(列表、字符串、元組等)的結合,它將重復非數字型數據。

print("0" * 3) # '000'
print((0,) * 3) # (0, 0, 0)

在創建一個多個列表元素的元組時候,如果使用下面的代碼:

t1 = ([0],) * 3
print(t1) # ([0], [0], [0])

會帶來意想不到的問題:我們對元組中的第一個列表元素中的數據進行算數運算(自增 1)

t1[0][0] += 1
print(t1) # ([1], [1], [1])

我們發現元組中的所有列表元素內的數據都自增 1 了,我們不是只對第一個列表元素進行自增的嗎?

實際上,當我們執行 t1 = ([0],) * 3 的時候,不會創建一個包含三個列表組成的元組,而是創建一個包含 3 個 引用的元組,每個引用都指向同一個列表。

元組中的每個元素都是對同一個可變對象(列表)的引用,所以當我們修改其中的元素時,另外的對象也會跟著發生變化。

正確的方法應該是:

t2 = ([0], [0], [0])  
# 或者 t2 = tuple([0] for _ in range(3))
t2[0][0] += 1             
print(t2) # ([1], [0], [0])

在 python 的其他地方中也有這種類似的坑

def a_bugged_function(reused_list=[]):  
    reused_list.append("woops")         
    return reused_list                  
                                        
print(a_bugged_function())  # ['woops']            
print(a_bugged_function())  # ['woops', 'woops']            
print(a_bugged_function())  # ['woops', 'woops', 'woops']

可以看到,reused_list 在函數定義中被初始化為一個空列表 [],然后每次函數調用時都使用這個默認的空列表。

在第一次調用 a_bugged_function() 后,列表變成了 ['woops']。然后,在第二次和第三次調用中,它分別繼續被修改,導致輸出的結果為:

['woops']
['woops', 'woops']
['woops', 'woops', 'woops']

這是因為在函數定義中,如果將可變對象(例如列表)作為默認參數,會導致該對象在函數調用時被共享和修改:每次調用函數時,使用的都是同一個列表對象的引用。

為了避免這種情況,常見的做法是使用不可變對象(如 None)作為默認值,并在函數內部根據需要創建新的可變對象。

def a_fixed_function(reused_list=None):
    if reused_list is None:
        reused_list = []
    reused_list.append("woops")
    return reused_list

print(a_fixed_function())
print(a_fixed_function())
print(a_fixed_function())


責任編輯:武曉燕 來源: 咸魚運維雜談
相關推薦

2010-10-18 09:30:55

2022-08-03 13:11:43

數據機器學習

2024-08-17 12:14:06

2025-04-29 10:17:42

2010-03-31 17:00:09

F#

2022-07-22 15:55:32

Python代碼語言

2020-09-06 08:19:11

Python編程語言開發

2011-04-12 10:13:24

2017-03-10 17:00:28

編程語言

2017-04-05 08:39:20

機器學習模型梯度下降法

2011-09-16 09:38:19

Emacs

2022-04-24 15:21:01

MarkdownHTML

2024-11-26 08:20:53

程序數據歸檔庫

2014-01-03 14:09:57

Git學習

2020-03-02 14:20:46

PythonGitHub編程語言

2010-03-10 17:09:26

Python語言

2024-05-08 12:41:29

Python編程語言

2010-12-01 09:48:01

Linux部署

2022-10-10 15:28:45

負載均衡

2015-07-20 13:56:59

SDN
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 久久99久久99 | 免费播放一级片 | 日韩免费网站 | 欧美一区二区三区视频 | 国产欧美一区二区精品久导航 | 亚洲协和影视 | 亚洲国产成人av | 亚洲一区二区久久 | 欧美精品久久久 | av黄色在线| 国产一区免费视频 | 一本岛道一二三不卡区 | 欧美一区二区三区在线播放 | 91社影院在线观看 | 99热精品在线观看 | 亚洲欧美激情视频 | 91中文字幕在线 | 美女黄18岁以下禁止观看 | 99精品久久久国产一区二区三 | 日韩精品一区二区三区中文字幕 | 欧美精品一区二区三区视频 | 日韩在线一区二区三区 | 男女啪啪高潮无遮挡免费动态 | 麻豆视频在线免费看 | 亚洲三区在线 | 国产粉嫩尤物极品99综合精品 | 国产中文区二幕区2012 | 久久精品中文字幕 | 国产成人精品亚洲日本在线观看 | 美女一级毛片 | 亚洲欧美在线观看 | 亚洲成人免费 | 国产美女精品视频 | 在线亚洲欧美 | 青青草一区 | 特黄视频 | 红色av社区| 成人免费视频久久 | 国产视频一区二区在线观看 | 久久i| 自拍视频在线观看 |