Python实现的栈、队列、文件目录遍历操作示例
本文实例讲述了Python实现的栈、队列、文件目录遍历操作。分享给大家供大家参考,具体如下:
一、栈与队列
1、栈stack
特点:先进先出[可以抽象成竹筒中的豆子,先进去的后出来]后来者居上
mystack=[] #压栈[向栈中存数据] mystack.append(1) print(mystack) mystack.append(2) print(mystack) mystack.append(3) print(mystack) #出栈[从栈中取数据] mystack.pop() print(mystack) mystack.pop() print(mystack)
2、队列queue
特点:先进先出[可以抽象成一个平放的水管]
#导入数据结构的集合 importcollections queue=collections.deque([1,2,3,4,5]) print(queue) #入队[存数据] queue.append(8) print(queue) queue.append(9) print(queue) #取数据 print(queue.popleft()) print(queue)
二、目录遍历
1、递归遍历目录
importos
defdiguigetAllDir(path,suojin):
#如果文件夹中只有文件则返回
ifos.path.isfile(path):
return
#如果为空文件夹则返回
list1=os.listdir(path)
iflen(list1)==0:
return
#遍历list1列表
foriteminlist1:
print(''*suojin,'%s'%item)
path1=os.path.join(path,item)
ifos.path.isdir(path1):
diguigetAllDir(path1,suojin+4)
#遍历当前目录
diguigetAllDir(os.getcwd(),0)
2、栈模拟递归遍历目录
也称为深度遍历
importos
defstackGetAllDir(path):
ifnotos.listdir(path):
return
liststack=[path]
listsuojin=[0]
print(liststack)
whilelen(liststack)!=0:
path=liststack.pop()#路径出栈
suojin=listsuojin.pop()#缩进空格个数出栈
print(''*suojin,os.path.basename(path))
ifos.path.isdir(path):
foriinos.listdir(path):#遍历路径下的全部文件
listsuojin.append(suojin+4)
liststack.append(os.path.join(path,i))#文件名拼接成相对路径后入栈
#遍历当前目录
stackGetAllDir(os.getcwd())
3、队列模拟递归遍历目录
也被称为广度遍历
importos
importcollections
defqueueGetAllDir(path=""):
ifnotos.listdir(path):
return
queue=collections.deque()
queue.append(path)
whilelen(queue)!=0:
filePath=queue.popleft()
fileList=os.listdir(filePath)#遍历filePath路径下的目录
forfilenameinfileList:
absFilePath=os.path.join(filePath,filename)#路径拼接
ifos.path.isdir(absFilePath):
print("目录:",filename)
queue.append(absFilePath)
else:
print("文件:",filename)
#遍历当前目录
queueGetAllDir(os.getcwd())
更多关于Python相关内容感兴趣的读者可查看本站专题:《Python数据结构与算法教程》、《Python加密解密算法与技巧总结》、《Python编码操作技巧总结》、《Python函数使用技巧总结》、《Python字符串操作技巧汇总》及《Python入门与进阶经典教程》
希望本文所述对大家Python程序设计有所帮助。