主要为一些简单的源代码的解析以及一些方法的理解。

  • 说明:这些文件都不是我写的,详情可参考Github上的内容

  • 批量修改文件类型

    def batch_rename(work_dir, old_ext, new_ext):
for filename in os.listdir(work_dir):
file_ext = os.path.splitext(filename)[1]
if file_ext == old_ext:
newfile = filename.replace(old_ext,new_ext)
os.rename(os.path.join(work_dir,file_ext ),os.path.join(work_dir,new_ext))
  1. os.listdir():列出当前目录下的所有文件,为文件的名称,而不是包含路径的名称,同样不包含子目录内的文件;
  2. os.path.splitext():分割文件,分为文件名和文件类型。文件类型为最后一个.和后缀名,文件名称为最后一个.前的所有内容。
  3. replace():字符串替换
  4. os.path.join():用组合的方式将文件路径和文件名称组合为绝对路径。不同的系统添加的内容不一样。和join一样,但功能特殊化。
  5. os.rename():修改文件名。
  • 新建文件夹
    def New_Folder(work_dir,Folder_name):
if not os.path.exists(os.path.join(work_dir,Folder_name)):
os.makedirs(os.path.join(work_dir,Folder_name))
    def New_Folder(Folder_name):
if not os.path.exists(Folder_name)):
os.makedirs(Folder_name)
  1. os.path.exists():判断文件夹是否存在
  2. os.makedirs():新建文件夹
  • 获取文件信息
import os
import stat
import time def get_fileInfo(filename):
file_stats = os.stat(filename)
file_info = {
"fname":filename,
"fmode":file_stats[stat.ST_MODE],
"fsize":file_stats[stat.ST_SIZE],
"f_lm":time.strftime("%d/%m/%Y %I:%M:%S %p",time.localtime(file_stats[stat.ST_MTIME])),
"f_la":time.strftime("%d/%m/%Y %I:%M:%S %p",time.localtime(file_stats[stat.ST_ATIME])),
"f_ct":time.strftime("%d/%m/%Y %I:%M:%S %p",time.localtime(file_stats[stat.ST_CTIME]))
}
return file_info; if __name__ == "__main__":
filename = input("Please input you file:")
fileinfo = get_fileInfo(filename)
print(fileinfo)
if stat.S_ISDIR(fileinfo["fmode"]):
print("Folder")
else:
print("filename :%(fname)s" % fileinfo)
  1. os.stat():获取文件的系统状态信息,返回一个系统状态信息的元组。

  2. stat模块

  3. time.localtime():格式化时间,输入为sec(秒)

  4. 针对字典的格式化输出,有两种方式:

    a. print("%(fname)s" % file_info)

    b. print("%s" % file_info["fname"])

  5. time.strftime():将当前时间格式化为字符串。

  6. stat.S_ISDIR():判断是否为目录,同样还有其他的文件类型。

  • 计算文件夹大小
def folder_size(folder_name):
fold_size = 0
for (path,dirs,files) in os.walk(folder_name):
for file in files:
filename = os.path.join(path,file)
fold_size += os.path.getsize(filename)
return fold_size
  1. os.walk():遍历文件夹,其中遍历为广度优先遍历。即,先遍历当前的文件夹,一步一步深入遍历,同时,根据参数不同遍历的方式也不同。

    a. path为当前的路径。

    b. dirs为当前路径是否包含子目录,没有为[]

    c. files为当前路径的文件列表。

  2. os.path.getsize():获取文件大小。

  • 将某一类型文件压缩
import os
from time import strftime def zip_files(filedir,fileend,zip_prog):
for files in os.listdir(filedir):
if files.endswith(fileend):
files1 = files + "." + strftime("%y-%m-%d") + ".zip"
os.chdir(filedir)
os.popen(zip_prog + " " + files1 + " " + files) #zip_prog = "zip.exe"
  1. zip.exe:压缩程序
  2. os.popen():调用exe,其中的参数和cmd参数一样,需要用空格区分,并且程序执行的目录页需要切换正确,不然会导致程序假执行的状态。
  3. os.chdir():切换工作目录
  4. files.endswith():判断后缀方法。
  5. from time import strftime:导入某个某块的某一部分,避免全部导入。
  6. os.system()和os.popen()虽然效果一样,但两者存在区别。明显的一点是,os.system和os.popen的返回结果已经执行效果并不相同。
  • 遍历检查DNS服务
import subprocess

file_Test = input("File In:")
file_Out = input("File Out:") fileout = open(file_Out ,"w"); for server in open(file_Test ):
subprocess.Popen(("nslookup" + " " + server ),stdout = fileout )
fileout.close()
  1. 详情参考subprocess.Popen()中的参数设定。
  2. nslookup命令参数,详情可nslookup /?(windows)
  3. stdout标准输出,将执行结果写入到file_out文件中。
  4. 写文件最后记得关闭文件。

Python简单源码解析的更多相关文章

  1. 『Python』源码解析_从ctype模块理解对象

    1.对象的引用计数 从c代码分析可知,python所有对象的内存有着同样的起始结构:引用计数+类型信息,实际上这些信息在python本体重也是可以透过包来一窥一二的, from ctypes impo ...

  2. 神经网络中 BP 算法的原理与 Python 实现源码解析

    最近这段时间系统性的学习了 BP 算法后写下了这篇学习笔记,因为能力有限,若有明显错误,还请指正. 什么是梯度下降和链式求导法则 假设我们有一个函数 J(w),如下图所示. 梯度下降示意图 现在,我们 ...

  3. 『Python』源码解析_源码文件介绍

    本篇代码针对2.X版本,与3.X版本细节不尽相同,由于两者架构差别不大加之本人能力有限,所以就使用2.X体验python的底层原理了. 一.主要文件夹内容 Include :该目录下包含了Python ...

  4. 机器学习实战(Machine Learning in Action)学习笔记————03.决策树原理、源码解析及测试

    机器学习实战(Machine Learning in Action)学习笔记————03.决策树原理.源码解析及测试 关键字:决策树.python.源码解析.测试作者:米仓山下时间:2018-10-2 ...

  5. 设计模式-简单工厂Coding+jdk源码解析

    感谢慕课geely老师的设计模式课程,本套设计模式的所有内容均以课程为参考. 前面的软件设计七大原则,目前只有理论这块,因为最近参与项目重构,暂时没有时间把Coding的代码按照设计思路一点点写出来. ...

  6. 简单理解 OAuth 2.0 及资料收集,IdentityServer4 部分源码解析

    简单理解 OAuth 2.0 及资料收集,IdentityServer4 部分源码解析 虽然经常用 OAuth 2.0,但是原理却不曾了解,印象里觉得很简单,请求跳来跳去,今天看完相关介绍,就来捋一捋 ...

  7. 量化交易中VWAP/TWAP算法的基本原理和简单源码实现(C++和python)(转)

    量化交易中VWAP/TWAP算法的基本原理和简单源码实现(C++和python) 原文地址:http://blog.csdn.net/u012234115/article/details/728300 ...

  8. Python2 基本数据结构源码解析

    Python2 基本数据结构源码解析 Contents 0x00. Preface 0x01. PyObject 0x01. PyIntObject 0x02. PyFloatObject 0x04. ...

  9. Theano:LSTM源码解析

    最难读的Theano代码 这份LSTM代码的作者,感觉和前面Tutorial代码作者不是同一个人.对于Theano.Python的手法使用得非常娴熟. 尤其是在两重并行设计上: ①LSTM各个门之间并 ...

随机推荐

  1. CWMP开源代码研究1——开篇之作

    原创作品,转载请注明出处,严禁非法转载.如有错误,请留言! email:40879506@qq.com 声明:本系列涉及的开源程序代码学习和研究,严禁用于商业目的. 如有任何问题,欢迎和我交流.(企鹅 ...

  2. flex 布局笔记

    1,今天遇到一个问题,就是当元素布局设置为了flex后,里面的内容只有文字,但是对text-align 属性设置无效,仔细想了下,是因为把display 设置为了flex后,flex将里面的文字也认为 ...

  3. JS中判断null、undefined与NaN的方法

    写了个 str ="s"++; 然后出现Nan,找了一会. 收集资料如下判断: 1.判断undefined: 代码如下: <span style="font-siz ...

  4. 配置容器configuring Containsers

    容器可以在运行时配置,相反的也可以通过应用程序的配置文件(或扩展配置文件)来配置. Unity的三个高级功能:泛型装饰链.解析器重写和数组注入. 1.配置开放式泛型来解析封闭式泛型 只要不是为封闭型泛 ...

  5. Windows phone应用开发[21]-图片性能优化

    在windows phone 中常在列表中会常包含比较丰富文字和图片混排数据信息. 针对列表数据中除了谈到listbox等控件自身数据虚拟化问题外.虽然wp硬件设备随着SDK 8.0 发布得到应用可使 ...

  6. RGW 负载均衡和高可用的几个方案对比

    注:在RGW网关主机网卡已经是10Gb的情况下,如下三个方案没有引入LVS:如果RGW是Gb网卡,可以考虑引入LVS做流量负载均衡. RGW部署采用 fastcgi+nginx 扩展性和可配置性更强. ...

  7. Python笔记(2)函数

    python中一切皆对象,函数也看做对象.函数被函数名所引用,但是同样的他也可以被其他标识符所引用,可以作为参数传递. def f(): return "hi" 可见a引用了函数返 ...

  8. 支付宝AR红包引出Python中的PIL小试

    这两天支付宝AR红包火了,周围的同学全在玩.可是我一直在想这个原理是什么?通过请教大神和思考,知道了它有两个限定条件:GPS地理位置和图片的识别.所以,只要我们有了这两个限定条件,就不难进行该红包的破 ...

  9. Beta版本——用户试用与调研报告

    1 引言 1.1 系统概述 ​ 毕设导师智能分配系统是一个用来简化传统手工匹配繁琐操作的系统.本系统将学生报志愿.系负责人收集整理数据.相关人员进行手工分配.反馈选择结果等繁琐的操作转移到线上.把毕设 ...

  10. Eclipse Maven3新建web项目

    环境: Eclipse Neon JDK1.8 先决条件: 本机下载apache-tomcat-8,解压,在Eclipse->preferences->server里配置安装目录.并在ec ...