Rumah > Artikel > pembangunan bahagian belakang > Apakah alat lelaran Python dan cara menggunakannya
Ia jauh lebih berkuasa daripada yang kelihatan pada pandangan pertama.
Titik pertama menggunakan range()
ialah memahami parameter: range(start, stop)
bermakna kita mula mengira dari nombor mula, termasuk nombor mula ; start
bermaksud kita berhenti mengira selepas mencapai nombor hentian, tetapi tidak termasuk nombor hentian! stop
, kita mendapat range(1, 10)
. Bermula pada [1, 2, 3, 4, 5, 6, 7, 8, 9]
tetapi tidak boleh pergi ke 1
. 10
dalam urutan kita, kita perlukan 10
: range(1, 11)
. [1, 2, 3, 4, 5, 6, 7, 8, 9, 10]
, ia akan menganggap bahawa permulaan julat ialah range(10)
. Dalam kes ini, kami mendapat 0
Anda akan sering melihat [0, 1, 2, 3, 4, 5, 6, 7, 8, 9]
digunakan dengan cara ini apabila ia digunakan untuk mengawal gelung tradisional. range()
ialah parameter range()
ketiga pilihannya: apabila anda menentukan , parameter range(start, stop, step)
ini Membolehkan anda menambah step
lebih besar daripada 1
<em>1</em>
setiap kali.
boleh digunakan untuk melaksanakan pencetakan 100 gandaan pertama 7, daripada 7
sendiri kepada 700
, termasuk: range(7, 701, 7)
akan melakukan ini. (Perhatikan bahawa saya menyatakan 701
pada penghujung untuk memastikan 700
disertakan.)
juga boleh digunakan untuk mencetak semua nombor ganjil kurang daripada 100: range(1, 100, 2)
.
Jika anda cuba menggunakan julat untuk mencetak semua gandaan 7, anda mungkin perasan bahawa hasilnya tidak seperti yang anda jangkakan:
sevens = range(7, 701, 7) print(sevens)
cetakan arahan cetak Frasa teks range(7, 701, 7)
. Penemuan bukanlah apa yang kita mahu!
Ingat bahawa range()
mengembalikan objek serupa dengan lelaran (python 2x mengembalikan senarai). Untuk menyimpannya betul-betul sebagai senarai, kita perlu menukarnya list()
kepada senarai dengan membungkusnya dalam fungsi: Dikehendaki - senarai 100 gandaan pertama 7! Split
Sebelum kita mendapat semua manfaat lelaran baharu ini, saya ingin memperkenalkan anda kepada notasi indeks lanjutan, yang membolehkan kami bermula dengan lebih berkuasa daripada bekas yang dipesan Pilih elemen, seperti senarai.
sevens = list(range(7, 701, 7)) print(sevens)
Sama ada anda sedar atau tidak, anda sudah mengetahui tatatanda indeks biasa. dossiers = ['Sir Vile', 'Dr. Belljar', 'Baron Grinnit', 'Medeva', 'General Mayhem', 'Buggs Zapper', 'Jacqueline Hyde', 'Jane Reaction', 'Dee Cryption']
Ini mengembalikan elemen kedua bekas (indeks
Mudah, bukan? Hampir semua bahasa menyediakan tingkah laku ini.
Jadi, bagaimana jika kita mahukan elemen kedua dan ketiga?
print(dossiers[1]) >>> Dr. Belljar
Apa yang baru berlaku? Dalam tatatanda indeks lanjutan, kami mempunyai tiga parameter, dipisahkan oleh titik bertindih: 1
, dossiers
dan
! Mereka juga berfungsi dengan cara yang sama. (Sudah tentu, kami meninggalkan parameter ketiga [
] dalam contoh di atas.)start
Perhatikan bahawa contoh mencetak stop
(indeks step
) dan range()
(indeks step
), tetapi
Dr. Belljar
kerana parameter 1
terpaksa berhenti. Baron Grinnit
2
Pastikan ambil perhatian bahawa mestilah lebih kecil daripada Medeva
stop
sebelum anda boleh mendapatkan hasilnya! Terdapat satu pengecualian, walaupun, yang akan kita bincangkan kemudian.
Sekarang, bagaimana jika anda mahu start
semua elemen lain bermula dari yang kedua?
print(dossiers[1:3]) >>> ['Dr. Belljar', 'Baron Grinnit']
stop
Anda akan perasan bahawa kami tidak menyatakan Kerana kami tidak begitu perlu! Notasi indeks lanjutan membolehkan anda meninggalkan sebarang hujah selagi anda mempunyai titik bertindih untuk memisahkannya. Memandangkan parameter kedua ditinggalkan, kami hanya meletakkan tambahan selepasnya di tempat yang sepatutnya. 扩展索引符号使 打印出列表中的最后一项。负数代表从列表末尾开始计数!这感觉有点奇怪,因为我们习惯于从 鉴于此,我们如何打印最后三个项目?我们可能会这样尝试,但它实际上不起作用...... 这将返回一个空列表。为什么?请记住, 现在我们得到了最后一个元素。如果我们想要最后三个,那就把 如果我们在第三个参数 看起来这是将所有内容都逆向打印除了!事实上, 现在让我们尝试 这不仅反转了列表,而且跳过了所有部分元素。负数的 那么,如果我们想把所有东西放在一起怎么办?也许我们想以相反的顺序列出第二个、第三个和第四个元素...... 注意: 你可以把它想象成摄影之旅的步行路线。 所以,要解决这个问题,我们需要交换我们的 说明: Python 还提供了 我们将在本节中探索的其余函数都与迭代对象一起使用。虽然我将在大多数示例中使用列表,但请记住,你可以使用任何可迭代的对象,包括 想象一下,你在一个可迭代的容器(例如列表)中获得了一大堆数据,例如包含数百个名称的列表。在将该列表输入到你的超级算法之前,你希望通过检查每个元素中是否存在异常值来节省一些处理时间。 这就是 你可能还记得,空字符串 ( 乍一看,这些似乎不是很有用,但是当与其他一些工具结合使用时,甚至与列表解析(稍后部分)结合使用时,它们可以节省大量时间! 在循环中,如果你需要访问列表的值及其索引,你可以使用该 但是 这给了我们... 我们可以从中得出一个简洁的模式,但我们必须从<em>1</em>而不是0开始枚举。果然,我们可以通过传递起始计数数字作为第二个参数来实现。我们还将稍微调整我们输出的信息,简化一下输出格式。 当我们运行它时,我们得到... 假设我们正在跟踪在一堆地点找到的线索数量,将它们存储在字典中。对于这个例子,我将在最后一节中借用和调整字典...... 也许我们需要找到所有有线索的地点,而忽略其余的。我们将首先编写一个函数来测试特定的键值元组对。这似乎是一个荒谬的过度复杂化,但一会儿会有用: 我们将字典中的每一对作为元组提交给函数, 我们使用 请注意,我们不包括 果然,运行该代码会打印出我们有线索的五个地点(值 > 在本系列的后面部分,我们将学习 lambdas匿名函数,我们不用单独定义函数。代码如下...... 假设我们有一个华氏温度列表: 我们想将这些都转换为摄氏度,所以我们为此编写了一个函数。 我们可以使用该 请记住,我们将函数对象 运行该循环输出: 让我们继续使用刚刚的温度列表例子。如果我们想在列表中找到最低或最高,我们可以分别使用 注意:与可迭代对象无关,你还可以使用这些函数来查找你提供给它的参数列表中的最小或最大参数,例如 通常,你需要对可迭代对象进行排序。Python 通过 输出如下... 大多数时候,扩展索引符号 例如,我用 程序输出如下... 另一个快速的内置函数是 这样做的一种用途是更早地找到这些温度的平均值。你可能还记得该 还记得前面那个关于地点和线索的例子吗?想象一下,我们得到的信息不是在字典中,而是在两个列表中: 那么刚刚的方法就不能实现查找了,但是在现实世界中确实存在我们会以这种方式获取数据的场景。 值得庆幸的是, 当然,在这种情况下,两个列表的长度相同,所以结果是相当明显的。让我们使用 zip 中的数据创建一个新列表,并将其打印出来。 这给了我们一个与我们 事实上,如果我回忆起我 和以前一样,输出... 我已经介绍了几乎所有 Python 用于处理可迭代对象的内置函数,但反向分割
(start, stop, step)
逻辑更进一步,允许你反向分割!一开始这有点绕脑筋,但是请坚持住……print(dossiers[-1])
0
索引开始计数,但负零并不是真正的有意义的数,所以我们从-1
开始。print(dossiers[-1:-4])
>>> []
start
必须小于 stop
,即使在使用负索引时也是如此。所以,我们必须把-4
作为我们的start
,因为-4 < -1
。print(dossiers[-4:-1])
>>> ['Buggs Zapper', 'Jacqueline Hyde', 'Jane Reaction']<p data-id="p838747a-R5xjXqGa">这更接近了,但仍然存在问题。<code>Dee Cryption</code>是我们的最后一个元素,它在哪里呢?<strong>记住,</strong><code><strong>stop</strong></code><strong>是停止计数的数字,且不包含当前数字。</strong>但我们不能只用<code>dossiers[-4]</code>,因为那只会给我们<code>Buggs Zapper</code>。并且<code>dossiers[-4:-0]</code>是无效。</p>
<p data-id="p838747a-5sJf0YUu">要解决这个问题的方法就是,告诉 Python 我们明确省略了第二个参数:<em>在我们的第一个参数后面加上一个冒号</em>!</p>
<pre class="brush:php;toolbar:false">print(dossiers[-4:])
>>> ['Buggs Zapper', 'Jacqueline Hyde', 'Jane Reaction', 'Dee Cryption']
-4
改为-3
......print(dossiers[-3:])
>>> ['Jacqueline Hyde', 'Jane Reaction', 'Dee Cryption']
step
中输入一个负数,你认为会发生什么?让我们尝试-1
在它前面加上两个冒号,表示我们想要整个列表。print(dossiers[::-1])
>>> ['Dee Cryption', 'Jane Reaction', 'Jacqueline Hyde', 'Buggs Zapper', 'General Mayhem', 'Medeva', 'Baron Grinnit', 'Dr. Belljar', 'Sir Vile']
step
设置为-1
颠倒了列表。-2
...print(dossiers[::-2])
>>> ['Dee Cryption', 'Jacqueline Hyde', 'General Mayhem', 'Baron Grinnit', 'Sir Vile']
step
行为与正数完全相同step
,只是它逆向工作!print(dossiers[2:5:-1])
>>> []
start
和stop
必须按顺序遍历。如果step
为正,则start
必须小于stop
;但是,如果step
为负数,则start
必须大于stop
!step
告诉你走哪条路,你的步幅应该有多大。一到就开始拍照start
,一遇到问题就stop
收起相机。start
and stop
。print(dossiers[5:2:-1])
>>> ['Buggs Zapper', 'General Mayhem', 'Medeva']
slice()
anditertools.islice()
函数,它们的行为方式大致相同。但是,它们都比扩展索引符号更受限制,因此你最好使用扩展索引符号而不是函数。操作迭代对象
range()
函数。all和any
all
函数的用途。dossiers = ['Sir Vile', 'Dr. Belljar', 'Baron Grinnit', 'Medeva', 'General Mayhem', 'Buggs Zapper', '', 'Jane Reaction', 'Dee Cryption']
print(all(dossiers))
>>> False
''
)在 Python 中的计算结果为False
。该all()
函数评估每个元素,并确保它返回True
。如果甚至一个计算结果为False
,该all()
函数也将返回 false。any()
以几乎相同的方式工作,但是它只需要一个元素来评估True
.enumerate
enumerate()
函数来完成。foo = ['A', 'B', 'C', 'D', 'E']
for index, value in enumerate(foo):
print(f'Element {index} is has the value {value}.')
enumerate()
,不仅限于列表。像所有这些其他函数一样,它适用于任何可迭代的对象,需要返回编号(或枚举)的每个值。例如,我们把它用在range()
。让我们用它来打印从 10 到 100 ( range(10,101,10)
) 的每一个 10 的倍数。下面是举例...for index, value in enumerate(range(10,101,10)):
print(f'Element {index} is has the value {value}.')
Element 0 is has the value 10.
Element 1 is has the value 20.
Element 2 is has the value 30.
Element 3 is has the value 40.
Element 4 is has the value 50.
Element 5 is has the value 60.
Element 6 is has the value 70.
Element 7 is has the value 80.
Element 8 is has the value 90.
Element 9 is has the value 100
for index, value in enumerate(range(10,101,10), 1):
print(f'{index} times 10 equals {value}')
1 times 10 equals 10
2 times 10 equals 20
3 times 10 equals 30
4 times 10 equals 40
5 times 10 equals 50
6 times 10 equals 60
7 times 10 equals 70
8 times 10 equals 80
9 times 10 equals 90
10 times 10 equals 100
filter
locations = {
'Parade Ground': 0,
'Ste.-Catherine Street': 0,
'Pont Victoria': 0,
'Underground City': 3,
'Mont Royal Park': 0,
'Fine Arts Museum': 0,
'Humor Hall of Fame': 2,
'Lachine Canal': 4,
'Montreal Jazz Festival': 1,
'Olympic Stadium': 0,
'St. Lawrence River': 2,
'Old Montréal': 0,
'McGill University': 0,
'Chalet Lookout': 0,
'Île Notre-Dame': 0
}
def has_clues(pair):
return bool(pair[1])
pair[1]
将会是值(例如('Underground City', 3)
)。如果线索数字是0
,bool()
函数将返回False
,那其他所有为True
的元素,就是我们想要的。filter()
对刚刚编写的函数来缩小字典范围。回想一下上一节,我们需要使用locations.items()
来获取键和值作为一对。for place, clues in filter(has_clues, locations.items()):
print(place)
has_clues
后面的括号。我们将实际函数作为对象传递!filter
将进行实际调用。0
)......Underground City
Humor Hall of Fame
Lachine Canal
Montreal Jazz Festival
St. Lawrence River
for place, clues in filter(lambda x:bool(x[1]), locations.items()):
print(place)
map
map()
函数的方式与 类似filter()
,只是它不是使用函数从可迭代对象中省略元素,而是用于更改它们。temps = [67.0, 72.5, 71.3, 78.4, 62.1, 80.6]
def f_to_c(temp):
return round((temp - 32) / 1.8, 1)
map()
函数将其应用于temps
中的每个值,从而生成可以在循环(或任何地方)中使用的迭代器。for c in map(f_to_c, temps):
print(f'{c}°C')
f_to_c
作为map()
的第一个参数传递,所以我们去掉括号!19.4°C
22.5°C
21.8°C
25.8°C
16.7°C
27.0°C
min和max
min()
ormax()
函数。这没什么新奇的。temps = [67.0, 72.5, 71.3, 78.4, 62.1, 80.6]
print(min(temps))
>>> 62.1
print(max(temps))
>>> 80.6
min(4, 5, 6, 7, 8)
,这将返回4
。sorted
sorted()
内置函数非常有效地做到了这一点。temps = [67.0, 72.5, 71.3, 78.4, 62.1, 80.6]
for t in sorted(temps):
print(t)
62.1
67.0
71.3
72.5
78.4
80.6
reversed
[::-1]
将允许你反转列表或其他有序迭代。但如果这不是唯一办法,你也可以使用reversed()
函数来反转。sorted()
与刚才的函数结合起来......temps = [67.0, 72.5, 71.3, 78.4, 62.1, 80.6]
for t in reversed(sorted(temps)):
print(t)
80.6
78.4
72.5
71.3
67.0
62.1
sum
sum()
,它将迭代中的所有元素添加在一起。当然,这只有在所有元素都可以添加在一起时才有效。len()
函数告诉我们容器中有多少元素。temps = [67.0, 72.5, 71.3, 78.4, 62.1, 80.6]
average = sum(temps) / len(temps)
print(round(average, 2))
>>> 71.98
zip
locations = ['Parade Ground', 'Ste.-Catherine Street', 'Pont Victoria', 'Underground City', 'Mont Royal Park', 'Fine Arts Museum', 'Humor Hall of Fame', 'Lachine Canal', 'Montreal Jazz Festival', 'Olympic Stadium', 'St. Lawrence River', 'Old Montréal', 'McGill University', 'Chalet Lookout', 'Île Notre-Dame']
clues = [0, 0, 0, 3, 0, 0, 2, 4, 1, 0, 2, 0, 0, 0, 0]
zip()
函数可以帮助我们处理这些数据,方法是使用迭代器将其聚合成元组,给我们(locations[0], clues[0]), (locations[1], clues[1]), (locations[2], clues[2])
等等。zip()
函数甚至不限于两个迭代;它可以尽可能多地压缩在一起!如果迭代的长度不同,“额外”内容会被放到最后。data = list(zip(locations, clues))
print(data)
.items()
之前从字典函数中得到的结构不同的结构![('Parade Ground', 0), ('Ste.-Catherine Street', 0), ('Pont Victoria', 0), ('Underground City', 3), ('Mont Royal Park', 0), ('Fine Arts Museum', 0), ('Humor Hall of Fame', 2), ('Lachine Canal', 4), ('Montreal Jazz Festival', 1), ('Olympic Stadium', 0), ('St. Lawrence River', 2), ('Old Montréal', 0), ('McGill University', 0), ('Chalet Lookout', 0), ('Île Notre-Dame', 0)]
filter()
的 lambda 函数,我可以将它调整为 use zip
,让我们完全从两个列表中工作:for place, clues in filter(lambda x:bool(x[1]), zip(locations, clues)):
print(place)
Underground City
Humor Hall of Fame
Lachine Canal
Montreal Jazz Festival
St. Lawrence River
itertools
itertools
模块中还有更多内容。我强烈建议阅读官方文档以了解更多信息。
Atas ialah kandungan terperinci Apakah alat lelaran Python dan cara menggunakannya. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!