资讯

精准传达 • 有效沟通

从品牌网站建设到网络营销策划,从策略到执行的一站式服务

for函数python,for函数是先判断还是先执行

python for 语句的使用方法?

Python 中的 for 语句和 C 或 Pascal 中的略有不同。通常的循环可能会依据一个等差数值步进过程(如 Pascal),或由用户来定义迭代步骤和中止条件(如 C ),Python 的 for 语句依据任意序列(链表或字符串)中的子项,按它们在序列中的顺序来进行迭代。例如(没有暗指):

10年积累的做网站、成都网站设计经验,可以快速应对客户对网站的新想法和需求。提供各种问题对应的解决方案。让选择我们的客户得到更好、更有力的网络服务。我虽然不认识你,你也不认识我。但先网站设计后付款的网站建设流程,更有宁武免费网站建设让你可以放心的选择与我们合作。

# Measure some strings:

... words = ['cat', 'window', 'defenestrate']

for w in words:

... print(w, len(w))

...

cat 3

window 6

defenestrate 12

在迭代过程中修改迭代序列不安全(只有在使用链表这样的可变序列时才会有这样的情况)。如果你想要修改你迭代的序列(例如,复制选择项),你可以迭代它的复本。使用切割标识就可以很方便的做到这一点:

python中for循环放在后面要怎么理解?

i等于9因为闭包,lambda生成之后i引用的就是for循环中的i

建议你看一下python的列表生成器,

f = [(lambda n : i + n) for i in range(10)] 等同于

f=[]

for i in range(10)

f.append(lambda n : i + n)

下面是相关内容

列表生成式即List Comprehensions,是Python内置的非常简单却强大的可以用来创建list的生成式。

举个例子,要生成list [1, 2, 3, 4, 5, 6, 7, 8, 9, 10]可以用range(1, 11):

range(1, 11)[1, 2, 3, 4, 5, 6, 7, 8, 9, 10]

但如果要生成[1x1, 2x2, 3x3, ..., 10x10]怎么做?方法一是循环:

L = [] for x in range(1, 11):...    L.append(x * x)

... L

[1, 4, 9, 16, 25, 36, 49, 64, 81, 100]

但是循环太繁琐,而列表生成式则可以用一行语句代替循环生成上面的list:

[x * x for x in range(1, 11)]

[1, 4, 9, 16, 25, 36, 49, 64, 81, 100]

写列表生成式时,把要生成的元素x * x放到前面,后面跟for循环,就可以把list创建出来,十分有用,多写几次,很快就可以熟悉这种语法。

for循环后面还可以加上if判断,这样我们就可以筛选出仅偶数的平方:

[x * x for x in range(1, 11) if x % 2 == 0]

[4, 16, 36, 64, 100]

还可以使用两层循环,可以生成全排列:

[m + n for m in 'ABC' for n in 'XYZ']

['AX', 'AY', 'AZ', 'BX', 'BY', 'BZ', 'CX', 'CY', 'CZ']

三层和三层以上的循环就很少用到了。

运用列表生成式,可以写出非常简洁的代码。例如,列出当前目录下的所有文件和目录名,可以通过一行代码实现:

import os # 导入os模块,模块的概念后面讲到 [d for d in os.listdir('.')] # os.listdir可以列出文件和目录['.emacs.d', '.ssh', '.Trash', 'Adlm', 'Applications', 'Desktop', 'Documents', 'Downloads', 'Library', 'Movies', 'Music', 'Pictures', 'Public', 'VirtualBox VMs', 'Workspace', 'XCode']

for循环其实可以同时使用两个甚至多个变量,比如dict的iteritems()可以同时迭代key和value:

d = {'x': 'A', 'y': 'B', 'z': 'C' } for k, v in d.iteritems():...     print k, '=', v... y = B

x = A

z = C

因此,列表生成式也可以使用两个变量来生成list:

d = {'x': 'A', 'y': 'B', 'z': 'C' } [k + '=' + v for k, v in d.iteritems()]

['y=B', 'x=A', 'z=C']

最后把一个list中所有的字符串变成小写:

L = ['Hello', 'World', 'IBM', 'Apple'] [s.lower() for s in L]

['hello', 'world', 'ibm', 'apple']

小结

运用列表生成式,可以快速生成list,可以通过一个list推导出另一个list,而代码却十分简洁。

思考:如果list中既包含字符串,又包含整数,由于非字符串类型没有lower()方法,所以列表生成式会报错:

L = ['Hello', 'World', 18, 'Apple', None]

[s.lower() for s in L]

Traceback (most recent call last):

File "stdin", line 1, in moduleAttributeError: 'int' object has no attribute 'lower'

使用内建的isinstance函数可以判断一个变量是不是字符串:

x = 'abc' y = 123 isinstance(x, str)True isinstance(y, str)False

请修改列表生成式,通过添加if语句保证列表生成式能正确地执行。

为什么python for函数的第一个变量不用事先定义变量就可以用?

听起来你之前应该有学习一些静态编程语言,比如C, 所有会有些先入为主的理解。

为什么“i”好像可以不用定义就能使用?这是语法规定 没什么好说。

“i”的值从0开始?因为rang(5)会生成了一个类似[0,1,2,3,4]的序列,而for语句会迭代这个序列并把它的值依次赋给变量“i”,第一次赋值的时候就是0。

至于“i”为什么是inti型,Python是动态类型语言并且它足够聪明 会自动推断合适的数据类型给变量,不用我们指定数据类型。

关于for语句和range()函数的解释

Python 的 for 语句与 C 或 Pascal 中的不同。Python 的 for 语句不迭代算术递增数值(如 Pascal),或是给予用户定义迭代步骤和暂停条件的能力(如 C),而是迭代列表或字符串等任意序列,元素的迭代顺序与在序列中出现的顺序一致。

内置函数 range() 可以生成算术级数,生成的序列不包含给定的终止数值:

range(start, stop[, step])

start: 计数从 start 开始。默认是从 0 开始。例如range(5)等价于range(0, 5);

stop: 计数到 stop 结束,但不包括 stop。例如:range(0, 5) 是[0, 1, 2, 3, 4]没有5

step:步长,默认为1。例如:range(0, 5) 等价于 range(0, 5, 1)

python关于for循环的几个函数

for ... in ...

// for ... in 字符串

for i in 'abc':

print(i)

'''

a

b

c

'''

// for ... in 数组

for i in ['a', 'b', 'c']:

print(i)

'''

a

b

c

'''

// for ... in 元组

for i in ('a', 'b', 'c'):

print(i)

'''

a

b

c

'''

// for ... in 字典(得到的是字典的key)

for k in {'学号':30,'姓名':'小明'}:

print(k)

'''

姓名

学号

'''

// for ... in 字典.items()(得到的是字典的key, value)

for k, v in {'学号':30,'姓名':'小明'}.items():

print(k, v)

'''

姓名 小明

学号 30

'''

for ... in range(...)

// for ... in range(num)

for i in range(3):

print(i)

'''

1

2

'''

// for ... in range(num1, num2)

for i in range(1, 3):

print(i)

'''

1

2

'''

// for ... in range(num1, num2, num3)

for i in range(3, 1, -1):

print(i)

'''

3

2

'''

for i in range(1, 5, 2):

print(i)

'''        

1

3

'''

倒叙

for i in reversed([1,2,3,4]):

print(i)

’‘’

4

3

2

1

‘’‘

又想得到遍历次数,又想得到数组值

for i,e in enumerate(array):

for i,e in enumerate(['21dw', 55, 22, 'rw']):

print(i, e)

'''

0 21dw

1 55

2 22

3 rw

'''

列表生成式

[...for ... in array]]

print([x * x for x in [2, 34, 324, 43]])

'''

[4, 1156, 104976, 1849]

'''

//相当于

list = []

for x in [2, 34, 324, 43]:

list.append(x * x)

print(list)

python如何实现for循环操作文件?

python用for循环遍历文件操作,代码如下:

#!\urs\bin\env python

#encoding:utf-8       #设置编码方式  

import os

import re

class loop_file:

def __init__(self, root_dir, short_exclude=[], long_exclude=[], file_extend=[]):

self.root_dir = root_dir

self.short_exclude = short_exclude

self.long_exclude = long_exclude

self.file_extend = file_extend

def __del__(self):

pass

def start(self, func):

self.func = func

return self.loop_file(self.root_dir)    

def loop_file(self, root_dir):

t_sum = []

sub_gen = os.listdir(root_dir)

for sub in sub_gen:

is_exclude = False

for extends in self.short_exclude:  ##在不检查文件、目录范围中

if extends in sub:              ##包含特定内容

is_exclude = True

break

if re.search(extends, sub):     ##匹配指定正则

is_exclude = True

break                    

if is_exclude:

continue            

abs_path = os.path.join(root_dir, sub)

is_exclude = False

for exclude in self.long_exclude:

if exclude == abs_path[-len(exclude):]:

is_exclude = True

break

if is_exclude:

continue

if os.path.isdir(abs_path):

t_sum.extend(self.loop_file(abs_path))

elif os.path.isfile(abs_path):            

if not "." + abs_path.rsplit(".", 1)[1] in self.file_extend:  ##不在后缀名 检查范围中

continue

t_sum.append(self.func(abs_path))

return t_sum    

if '__main__'==__name__:

root_dir = r'D:\harness\newshoppingcart\testcase\promo\single_promo'

short_exclude = ['.svn', '.*_new.rb']     ###不包含检查的短目录、文件

long_exclude = []                         ###不包含检查的长目录、文件

file_extend = ['.rb']                     ###包含检查的文件类型

lf = loop_file(root_dir, short_exclude, long_exclude, file_extend)

for f in lf.start(lambda f: f):

print f


当前名称:for函数python,for函数是先判断还是先执行
标题URL:http://cdkjz.cn/article/hogcdd.html
多年建站经验

多一份参考,总有益处

联系快上网,免费获得专属《策划方案》及报价

咨询相关问题或预约面谈,可以通过以下方式与我们联系

大客户专线   成都:13518219792   座机:028-86922220