本文实例讲述了Python学习笔记之For循环用法。分享给大家供大家参考,具体如下:
Python 中的For循环
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_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函数使用技巧总结》、《Python面向对象程序设计入门与进阶教程》、《Python数据结构与算法教程》、《Python字符串操作技巧汇总》、《Python编码操作技巧总结》及《Python入门与进阶经典教程》
希望本文所述对大家Python程序设计有所帮助。
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
稳了!魔兽国服回归的3条重磅消息!官宣时间再确认!
昨天有一位朋友在大神群里分享,自己亚服账号被封号之后居然弹出了国服的封号信息对话框。
这里面让他访问的是一个国服的战网网址,com.cn和后面的zh都非常明白地表明这就是国服战网。
而他在复制这个网址并且进行登录之后,确实是网易的网址,也就是我们熟悉的停服之后国服发布的暴雪游戏产品运营到期开放退款的说明。这是一件比较奇怪的事情,因为以前都没有出现这样的情况,现在突然提示跳转到国服战网的网址,是不是说明了简体中文客户端已经开始进行更新了呢?
更新日志
- 凤飞飞《我们的主题曲》飞跃制作[正版原抓WAV+CUE]
- 刘嘉亮《亮情歌2》[WAV+CUE][1G]
- 红馆40·谭咏麟《歌者恋歌浓情30年演唱会》3CD[低速原抓WAV+CUE][1.8G]
- 刘纬武《睡眠宝宝竖琴童谣 吉卜力工作室 白噪音安抚》[320K/MP3][193.25MB]
- 【轻音乐】曼托凡尼乐团《精选辑》2CD.1998[FLAC+CUE整轨]
- 邝美云《心中有爱》1989年香港DMIJP版1MTO东芝首版[WAV+CUE]
- 群星《情叹-发烧女声DSD》天籁女声发烧碟[WAV+CUE]
- 刘纬武《睡眠宝宝竖琴童谣 吉卜力工作室 白噪音安抚》[FLAC/分轨][748.03MB]
- 理想混蛋《Origin Sessions》[320K/MP3][37.47MB]
- 公馆青少年《我其实一点都不酷》[320K/MP3][78.78MB]
- 群星《情叹-发烧男声DSD》最值得珍藏的完美男声[WAV+CUE]
- 群星《国韵飘香·贵妃醉酒HQCD黑胶王》2CD[WAV]
- 卫兰《DAUGHTER》【低速原抓WAV+CUE】
- 公馆青少年《我其实一点都不酷》[FLAC/分轨][398.22MB]
- ZWEI《迟暮的花 (Explicit)》[320K/MP3][57.16MB]