专栏名称: Python小屋
清华出版社《Python程序设计》系列教材作者董付国的Python小屋。介绍Python基础语法知识、标准库、扩展库知识,探讨Python在各领域的应用。
目录
相关文章推荐
51好读  ›  专栏  ›  Python小屋

Python批量整理文件名小案例(附公众号第一批赠书活动中奖名单)

Python小屋  · 公众号  · Python  · 2017-06-29 09:23

正文

请到「今天看啥」查看全文


问题背景: 用了半年时间录制了200集Python视频,内容结合了我系列教材《Python程序设计基础》、《Python程序设计(第2版)》和《Python可以这样学》(作者:董付国,清华大学出版社出版)三本书的大部分内容。现在视频录制差不多告一段落了,想整理一个清单。

在资源管理器里查看,视频文件名的格式如下图所示:

现在想整理成下图所示的格式:


根据以上的需求,写了下面的代码用来整理这些文件名:

import os

import re


path = r'D:\Python教学视频'


avis = [fn[:-4]\

for fn in os.listdir(path)\

if fn.endswith( '.avi' )]


def sort (item):

'''首先按章节名字排序

然后按序号从小到大排序'''

index = item.index( ':' )

item = item[:index]

# 查找文件名中的第一组数字,序号

digits = re.findall( r'\d+' , item)[0]

# 返回值作为sort()方法的排序规则

return (item[:item.index(digits)],\

int (digits))


# 按指定规则进行排序

avis.sort(key=sort)


chapters = []

# 调整输出格式

for item in avis:

# 文件名中第一组数字之前的是“章”的名字

digits = re.findall( r'\d+' , item)[0]

index = item.index(digits)

chapter = item[:index]

if chapter not in chapters:

chapters.append(chapter)

print (chapter)

# 文件名中冒号后面是“节”的名字

print ( '\t' , item[item.index( ':' )+1:])



--------------我是分割线-------------

“Python小屋”公众号近期主要活动:

1、赠书活动: 详情请进入公众号以后通过菜单“最新资源”===>“历史文章分类表”进行查看

2、Python师资培训班: 8月6日-12日 ,济南,面向全国高校老师和企业朋友,通知详见 关于举办2017年暑期全国高校教师 “Python编程及应用”培训班通知 ,赠送Python教材2本、Python教学PPT超过1600页,Python教学视频140集,Python教学案例300个。补充说明:如果不需要安排住宿的话,5天学费2100元(含午饭)。


--------------又见分割线-------------

根据公众号赠书活动的精神,为庆祝微信公众号“Python小屋”开通一周年,于今天(2017年6月29日)上午8点给第1、1000、2000、3000、4000、5000、6000位关注的朋友赠书一套。下面是截图,请获赠的朋友通过公众号消息或留言把详细地址和收件人联系电话告诉我。








请到「今天看啥」查看全文