1. for循环
Python也有for循环,到现在还未看到它们的原因是:Python在其他方面表现出色,通常你不需要它们。
其它大多数语言没有像Python一样强大的list数据类型,所有你需要亲自做很多事情,指定开始、结束和步长来定义一定范围的整数或字符或其他可重复的实体。但在Python中,for循环简单地在一个列表上循环。
#-------------------------------------------------------------------------------
# coding: utf-8
# Purpose:for循环
#
# Author: zdk
#
# Created: 25/02/2013
# Copyright: (c) zdk 2013
#-------------------------------------------------------------------------------
if __name__ == '__main__':
li = ['a','b','c']
for s in li:
print(s)
print ("\n".join(li))
for i in range(5):
print(i) # 0 1 2 3 4
for i in range(len(li)):
print(li[i])
(1)for s in li: for循环的语法同list解析相似。li是一个list,而s将从第一个元素开始依次接收每个元素。
(2)像if语句或其他任意缩进块,for循环可以包含任意数目的代码行。
(3)range(n)生成一个从小于n的大于或等于0的整数的list,通过它可以实现传统风格的for循环的list的遍历
for循环不仅仅用于简单计数,它们可以遍历任何类型的东西。下面就是一个for循环遍历dictionary的例子。
import os
for k,v in os.environ.items():
print("%s=%s" %(k,v))
print("\n".join(["%s=%s" %(k,v) for k,v in os.environ.items()]))
(1)os.environ 返回系统上所定义的环境变量的dictionary,os.environ.items()返回一个tuple的list:[(key1,value1),(key2,value2)……]。for循环对这个list进行遍历。
(2)k,v in os.environ.items() 即使用了多变量赋值。
2. 使用 sys.modules
与其他任何Python的东西一样,模块也是对象,只要导入了,总可以用全局dictionary sys.modules来得到一个模块的引用。
import sys
from fileinfo import FileInfo
print("\n".join(sys.modules.keys()))
print(sys.modules[FileInfo.__module__]) #<module 'fileinfo' from 'D:\编程\python\codes\fileinfo.py'>
(1)sys.modules[FileInfo.__module__],每个Python类都有一个内置的属性__module__,它定义了这个类模块的名字,将它与sys.modules字典符合使用,你可以得到定义了某个类的模块的引用。
3. 与目录共事
os.path模块下有几个操作文件与目录的函数。这里我们看看如何操作目录名和列出一个目录的内容。
#-------------------------------------------------------------------------------
# coding: utf-8
# Purpose:与目录共事
#
# Author: zdk
#
# Created: 25/02/2013
# Copyright: (c) zdk 2013
#-------------------------------------------------------------------------------
import os
if __name__ == '__main__':
print(os.path)
print(os.path.join("D:\\","tes.log")) #D:\tes.log
print(os.path.expanduser("~")) # C:\Users\zdk
print(os.path.join(os.path.expanduser("~"),"txl.txt")) #C:\Users\zdk\txl.txt
print(os.path.split("d:\\test.log")) #('d:\\', 'test.log')
print(os.path.splitext("test.log")) #('test', '.log')
print(os.listdir(os.path.expanduser("~"))) # 列出跟目录下的所有文件和目录
print("==================")
print([f for f in os.listdir("c:\\")
if os.path.isfile(os.path.join("c:\\",f))]) #列出C盘下的所有文件
print("==================")
print([f for f in os.listdir("c:\\")
if os.path.isdir(os.path.join("c:\\",f))]) #列出C盘下的所有目录
(1)os.path是一个模块的引用;join函数把一个或多个部分路径名连接成一个。
(2)expanduser将使用~来表示当前用户根目录。
(3)os.path.split("d:\\test.log"),spilt函数对全路径进行分割,返回一个包含路径和文件名的tuple。
(4)spliext函数可以对文件名进行分割,返回一个包含了文件名和扩展名的tuple。
(5)listdir函数接收一个路径名,并返回那个目录的内容的list。
(6)listdir同时返回文件和文件夹,你可以使用列表过滤和os.path模块的isfile函数过滤文件、isdir函数过滤目录。
NOTE:
只要有可能,你就应该使用在os和os.path下的函数进行文件、目录和路径的操作。
import glob
print(glob.glob("c:\\*.txt")) #匹配c盘下的所有txt文件
print(glob.glob("c:\\*\\*.txt")) #匹配c盘及其所有子目录下的txt文件
(1)glob可以使用正则来进行更加强大的匹配。