百度360必应搜狗淘宝本站头条
当前位置:网站首页 > IT技术 > 正文

Python教程:for循环语句(python中for循环语法)

wptr33 2025-07-21 18:17 6 浏览

循环(loop)是生活中常见的现象,如每天的日升日落,斗转星移,都是循环,编程语言的出现就是为了解决现实中的问题,所以也少不了要循环。

for循环

在这里我用一个例子来具体解析一下for循环:

>>> name = 'rocky'
>>> for i in name:
...    print(i)
... 
r
o
c
k
y123456789复制代码类型:[python]

上述的例子就是实现的for循环,下面具体说一下它的运行过程:

name=‘rocky’是赋值语句,实现了变量和字符串之间的引用关系。

foriinname:for是发起循环的关键词;iinname是for循环的规则,字符串类型的对象是序列类型,能够从左到右一个个的按照索引读出每个字符,于是变量i就按照索引顺序,从第一个字符开始,依次获得该字符的引用。

当i=‘r’的时候,开始执行print(i),打印出字母r;然后循环第2次,让i=‘o',执行print(i),打印出字母o...如此循环下去,直到最后一个字符被打印出来,循环自动结束。

因为可以通过使用索引得到序列对象的某个元素,所以还可以通过下面的循环方式实现相同的效果:

>>> for i in range(len(name)):
...    print(name[i])
... 
r
o
c
k
y12345678复制代码类型:[python]

字符串,列表,元组,字典和集合等都可以用类似于上面的方式来循环。

>>> my_dict = dict([('name','rocky'),('like','python'),('age',23)])
>>> my_dict
{'age': 23, 'name': 'rocky', 'like': 'python'}
>>> for k in my_dict:
...    print(k)
... 
age
name
like123456789复制代码类型:[python]

这上面的循环,其实就是读取了字典的“键”,其实还有一个读取“键”的方式--dict.keys(),得到的字典的“键”组成的可迭代的对象。

>>> for k in my_dict.keys():
...    print(k)
... 
age
name
like123456复制代码类型:[python]

除了获得“键”值外,当然还有获取“值”啦,获取值用dict.values(),这个自己可以自行尝试一下。

还有一种方法可以以元组的方式返回键/值对,用的是dict.items()。

>>> for k in my_dict.items():
...    print(k)
... 
('age', 23)
('name', 'rocky')
('like', 'python')123456复制代码类型:[python]

这里有一点要说明的是,for循环应用的对象必须是可迭代的,如何判断一个对象是不是可迭代的,我们可以用collection这个标准库,具体使用如下:

>>> import collections
>>> isinstance(1,collections.Iterable)
False123复制代码类型:[python]

当然我说这个的意思并不是要你在每次使用for循环之前,非要判断某个对象是否可迭代,因为在上面我说过了,for循环可以用在字符串,列表,字典,元组和集合,你可以理直气壮的去用。

并行迭代

我提过多次“迭代”这个词,可以看出它在Python中占有重要的位置,其实“迭代”在Python中的表现就是for循环,从对象中获得一定数量的元素。在这里我们介绍一个方便的技巧,在使用迭代的时候,可以通过zip()函数对多个序列进行并行迭代。请看下面的例子:

>>> name = ['rocky','leey','zhangsan']
>>> language = ['python','c++','java','c#']
>>> names = ['rocky','leey','zhangsan']
>>> languages = ['python','c++','java','c#']
>>> for name,language in zip(names,languages):
...    print(name,' like ',language)
...
('rocky', ' like ', 'python')
('leey', ' like ', 'c++')
('zhangsan', ' like ', 'java')12345678910复制代码类型:[python]

zip()在最短的序列用完的时候就会停止,上面的例子中列表language是最长的,所以我们无法填充列表。除非人工扩展其它列表。

列表解析

我们先来看一个小问题,求1~9每个整数的平方,并且将结果放在列表中打印出来。

>>> power = []
>>> for i in range(1,10):
...     power.append(i*i)
...
>>> power
[1, 4, 9, 16, 25, 36, 49, 64, 81]123456复制代码类型:[python]

Python有一个非常强大的功能,就是列表解析,我们把上面的例子用列表解析写出来:

>>> power = [x ** 2 for x in range(1,10)]
>>> power
[1, 4, 9, 16, 25, 36, 49, 64, 81]123复制代码类型:[python]

看到上面的结果,我就问你怕不怕?惊不惊?这就是Python!追求简洁优雅的Python!上面我写的代码,都能用列表解析来重写,感兴趣的可以试试。

「链接」

相关推荐

oracle中merge into语句详解(oracle的merge语句)

由于工作中使用,研究了mergeinto语句是insert与update语句的结合,可以同时实现update和insert的功能。一、mergeinto语句的语法。MERGEINTOsch...

N张图告诉你K-DB为什么能全面兼容Oracle?

不是每一款数据库都能全面兼容Oracle,就像不是所有数据库都可以被称之为K-DB。一般数据库能做到的SQL标准和函数上兼容Oracle,而K-DB则能实现更多,在数据库体系架构、集群方式、数据库对象...

ORACLE 错误代码及解决办法(oracle错误码942)

ORA-00001:违反唯一约束条件(.)错误说明:当在唯一索引所对应的列上键入重复值时,会触发此异常。ORA-00017:请求会话以设置跟踪事件ORA-00018:超出最大会话数ORA-00...

SQL知识大全三):SQL中的字符串处理和条件查询

点击上方蓝字关注我们今天是SQL系列的第三讲,我们会讲解条件查询,文本处理,百分比,行数限制,格式化以及子查询。...

LabVIEW实现Oracle数据库的访问(深入浅出labview数据库应用)

1.安装Oracle客户端下载:从Oracle官方网站下载适用于Windows操作系统的Oracle驱动程序。确保下载的版本与LabVIEW环境和操作系统兼容。...

Oracle查询语句,你知道几个?(oracle常用查询语句)

介绍以下非常有用的Oracle查询语句,主要涵盖了日期操作,获取服务器信息,获取执行状态,计算数据库大小等方面的查询。日期/时间查询1、获取当前月份的第一天运行这个命令能快速返回当前月份的第一天,可...

Oracle数据库中判断字段不为空?(oracle数据库中判断字段不为空的函数)

Oracle数据库中如何判断字段不为空在Oracle数据库中,判断字段(列)不为空通常涉及到几种不同的场景和需求。下面是一些常见的方法来检查字段是否不为空:1.使用NVL函数NVL函数可以用来将NU...

Oracle 字典表使用函数自动转码,自定义函数传参

创建函数模板CREATEORREPLACEFUNCTIONdic_val--定义函数(dict_idINVARCHAR2,codeINVARCHAR2)--定义参数RETURN...

从上百个字段到1个CLOB:Oracle JSON存储实战指南

陆沉盯着左右两个屏幕上显示的数据格式文档,右手小拇指无意思地一下又一下的敲击着机械键盘的Ctrl键,在清脆的“哒哒”声中思考着。...

程序员面试中问到的Oracle常用数据类型

Oracle中常用数据类型有:1、字符类型1.1、定长字符1.1.1、Char字符长度不够自动在右边加空格符号。最大存2000个字符,当字符长度超出2000个报错。不指定大小默认为1。1.1.2、...

了解 Oracle 中单引号与双引号的用法,一篇文章教会你!

无论测试或者开发,对数据库的增删改查都是家常便饭。但有些小知识是经常被忽略,却又不能不去了解的,例如单引号和双引号的用法和区别,看完这一篇,你肯定会有收获。...

Oracle字符串转日期错误,试试TO_TIMESTAMP函数

最近,在工作中,发现有些字符串格式无法转换成日期格式,如下图:这种to_date是无法转换的,会报错,因此,需要用到:TO_TIMESTAMP,具体格式如下:TO_TIMESTAMP(字段名,...

oracle——空字符串('')不能用和!=

oracle——空字符串('')不能用<>和!=最近在查询空字符串的数据时发现查询不出数据。后来发现以前的写法在oracle中不能用。记录一下:数据如下:...

oracle的listagg函数,可以把多行转为一个字符串

oracle的listagg函数可以把多行转为一个字符串,用起来很方便,示例如下:witht1as(select'001'asitemcode,'苹果'...

MySQL 教程的天花板--入门到高级(mysql实用教程)

给大家推荐一套MySQL的教程,堪称MySQL教程的天花板。此教程包含...