Python学习笔记之For循环⽤法详解
本⽂实例讲述了Python学习笔记之For循环⽤法。分享给⼤家供⼤家参考,具体如下:
Python 中的For循环
Python 有两种类型的循环:for 循环和 while 循环。for 循环⽤来遍历可迭代对象。学python需要什么
可迭代对象是每次可以返回其中⼀个元素的对象, 包括字符串、列表和元组等序列类型,以及字典和⽂件等⾮序列类型。还可以使⽤迭代器和⽣成器定义可迭代对象
For 循环⽰例:
# iterable of cities
cities = ['new york city', 'mountain view', 'chicago', 'los angeles']
# for loop that iterates over the cities list
for city in cities:
print(city.title())
For 循环的组成部分:
循环的第⼀⾏以关键字for开始,表⽰这是⼀个for循环
然后是iteration_variable in iterable,表⽰正在被遍历的是可迭代的对象,并且⽤迭代变量表⽰当前正在被处理的可迭代对象的元素。在此⽰例中,迭代变量 city 在第⼀次迭代时将是 “new york city”,在第⼆次迭代时将是 mountain view。
for循环头部始终以英⽂冒号:结束。
for循环头部之后的是在此for循环的每次迭代时运⾏的缩进代码块。在此块中,我们可以使⽤迭代变量访问当前正在被处理的元素的值。
你可以随意命名迭代变量。常见模式是为迭代变量和可迭代对象指定相同的名称,但是分别使⽤单复数形式(例如 ‘city'和 ‘cities')
For 循环创建和修改列表:
# Creating a new list
cities = ['new york city', 'mountain view', 'chicago', 'los angeles']
capitalized_cities = []
for city in cities:
capitalized_cities.append(city.title())
修改列表稍微复杂些,需要使⽤新的函数:range():
range()是⼀个内置函数,⽤于创建不可变的数字序列。它有三个参数,必须都为整数。range(start=0, stop, step=1) start是该序列的第⼀个数字,stop⽐该序列的最后⼀个数字⼤ 1,step是该序列中每个数字之间的差。如果未指定的话,start默认为 0,step 默认为 1(即上述 =0 和 =1)。
如果你在range()的括号⾥指定⼀个参数,它将⽤作 stop 的值,另外两个参数使⽤默认值。E.g. list(range(4))返回 [0, 1, 2, 3]
如果你在range()的括号⾥指定两个参数,它们将⽤作 start 和 stop 的值,step 将使⽤默认值。 E.g. list(range(2, 6))返回 [2, 3, 4, 5]
注意,在这些⽰例中,我们将 range 封装在列表中。因为 range 本⾝的输出是⼀个 range 对象。我们可以通过将其转换为列表或在for循环中遍历它,查看 range 对象中的值集合。
我们可以使⽤ range 函数为 cities 列表中的每个值⽣成索引。这样我们便可以使⽤cities[index]访问列表中的元素,以便直接修改 cities 列表中的值。
cities = ['new york city', 'mountain view', 'chicago', 'los angeles']
for index in range(len(cities)):
cities[index] = cities[index].title()
虽然修改列表是 range 函数的⼀个⽤途,但是并⾮只有这⼀个⽤途。你将经常使⽤ range 和 for 循环重复某个操作⼀定的次数。
for i in range(3)
print("Hi!")
For 循环[相关练习]
写⼀个遍历 names 列表以创建 usernames 列表的 for 循环。要为每个姓名创建⽤户名,使姓名全⼩写并⽤下划线代替空格。对以下列表运⾏ for 循环:
names = ["Joey Tribbiani", "Monica Geller", "Chandler Bing", "Phoebe Buffay"]
应该会创建列表:
usernames = ["joey_tribbiani", "monica_geller", "chandler_bing", "phoebe_buffay"]
解决⽅案如下:
names = ["Joey Tribbiani", "Monica Geller", "Chandler Bing", "Phoebe Buffay"]
usernames = []
# write your for loop here
for name in names:
usernames.append(name.lower().replace(" ", "_"))
print(usernames)
假设我们不想创建新的列表,⽽是修改 names 列表本⾝,并编写以下代码。下⾯的代码有什么作⽤?
names = ["Joey Tribbiani", "Monica Geller", "Chandler Bing", "Phoebe Buffay"]
for name in names:
name = name.lower().replace(" ", "_")
print(names)
分析:这段代码没有效果。在每次迭代时,name 变量设为从该列表中获取的⼀个字符串。然后赋值语句创建⼀个新的字符串(name.lower().replace(" ", "_")) 并将 name 变量更改为该字符串。要修改该列表,你必须使⽤ range 对该列表本⾝操作。
写⼀个使⽤range()遍历 usernames 中的职位以修改该列表的 for 循环。和上⼀道练习⼀样,将每个姓名改成全⼩写形式并⽤下划线代替空格。运⾏for循环后,以下列表
usernames = ["Joey Tribbiani", "Monica Geller", "Chandler Bing", "Phoebe Buffay"]
应该更改为:
usernames = ["joey_tribbiani", "monica_geller", "chandler_bing", "phoebe_buffay"]
解决⽅案如下:
usernames = ["Joey Tribbiani", "Monica Geller", "Chandler Bing", "Phoebe Buffay"]
# escreva seu loop for aqui
for index in range(len(usernames)):
usernames[index] = usernames[index].lower().replace(" ", "_")
print(usernames)
标记计数器:写⼀个for循环,⽤于遍历字符串列表 tokens 并数⼀下有多少个 XML 标记。
解决⽅案如下:
tokens = ['<greeting>', 'Hello World!', '</greeting>']
count = 0
# write your for loop here
for t in tokens:
if t[0] == '<' and t[-1] == '>':
count += 1
print(count)
创建 HTML 列表:写⼀个 for 循环,⽤于遍历字符串列表并创建单个字符串 html_str,它是⼀个 HTML 列表。例如,如果列表是items = ['first string', 'second string],输出 html_str 应该会输出:
<ul>
<li>first string</li>
<li>second string</li>
</ul>
解决⽅案如下:
items = ['first string', 'second string']
html_str = "<ul>\n"
for item in items:
html_str += "<li>" + item + "</li>\n"
html_str += "</ul>"
print(html_str)
关于Python相关内容感兴趣的读者可查看本站专题:《》、《》、《》、《》、《》及《》希望本⽂所述对⼤家Python程序设计有所帮助。