阿里程序员Python培训分享For循环用法详解

阿里程序员Python培训分享For循环用法详解,结合实例形式详细分析了Pythonfor循环的功能、原理、用法及相关操作注意事项,下面我们一起来看一下吧。

  Python有两种类型的循环:for循环和while循环。for循环用来遍历可迭代对象。

  可迭代对象是每次可以返回其中一个元素的对象,包括字符串、列表和元组等序列类型,以及字典和文件等非序列类型。还可以使用迭代器和生成器定义可迭代对象

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_variableiniterable,表示正在被遍历的是可迭代的对象,并且用迭代变量表示当前正在被处理的可迭代对象的元素。在此示例中,迭代变量city在第一次迭代时将是“newyorkcity”,在第二次迭代时将是mountainview。

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 = ['', 'Hello World!', '']

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=['firststring','secondstring],输出html_str应该会输出:

  • first string
  • second string

解决方案如下:

items = ['first string', 'second string']

html_str = "

    \n"

    for item in items:

    html_str += "

  • " + item + "
  • \n"

    html_str += "

"

print(html_str)

这边整理了相关的资料,私信“   1   ”获取哦

你可能感兴趣的:(阿里程序员Python培训分享For循环用法详解)