根据本人的学习,按照理解整理和补充了python模块的相关知识,希望对于一些需要了解的python爱好者有帮助!

一、软件开发规范——分文件

当代码存在一个py文件中时:

1.不便于管理 (修改,增加)
2.可读性差
3.加载速度慢

Django——雏形(约定俗称)

1.启动文件 启动接口
2.公共文件 大家需要的功能
3.配置文件(静态文件) 变量
4.主逻辑 核心
5.用户相关数据 账号和密码等文件
6.日志 记录主要信息,记录开发人员的行为

高内聚

二、sys

sys python解释器做交互

import sys

print(sys.path)		# 模块查找的顺序

print(sys.argv)		# 只能在终端执行,第一个元素是本身路径,列表形式

print(sys.modules)		# 查看加载到内存的模块

print(sys.platform)		# 查看当前操作系统平台mac - darwin	win - win32
print(sys.version) # 查看python当前版本信息 扩展知识:
mac -- linux 查看 ls 苹果系统
win 查看 dir Windows系统
可以用来判断,已达到系统操作兼容

三、序列化

1.json

4个方法2组

dumps loads ——用于网络传输
dump load ——用于文件存储

​ 将数据类型转换成字符串(序列化),将字符串转成原数据类型(反序列)

​ 能够序列:字典,列表,元组序列后变成列表

import json
dic = {"key":1}
a = json.dumps(dic)
print(a, type(a)) #将数据类型转换成字符串(序列化)
结果:{"key": 1} <class 'str'> a1 = json.loads(a)
print(a1, type(a1)) #将字符串重新转为原数据类型(反序列化)
结果:{'key': 1} <class 'dict'> f = open("a", "a", encoding="utf-8")
a = json.dump(dic, f) # 将原数据类型转换成字符串,写入到文件
print(a,type(a))
结果:{"key": 1} <class 'str'> f = open("a", "r", encoding="utf-8")
a1 = json.load(f) #将文件中的字符串转换成原数据类型
print(a1,type(a1)) #a1["key"] = 1,a1为字典的键
结果:{'key': 1} <class 'dict'>

在文件中如果写入多行——"\n"

import json
dic = {"key": 1}
f = open("a", "a", encoding="utf-8")
f.write(json.dumps(dic) + "\n") #字符串 + "\n"
f.write(json.dumps(dic) + "\n")
f.write(json.dumps(dic) + "\n")
结果:{"key": 1} #写入文件的字符串
{"key": 1}
{"key": 1}

2.pickle

只有python有,几乎可以序列python中所有数据类型,匿名函数不能序列,函数可以
import pickle
def func():
print(1)
import pickle
a = pickle.dumps(func) #将原数据类型转换成类似字节的内容
结果:b'\x80\x03c__main__\nfunc\nq\x00.' print(pickle.loads(a)) #将类似字节的内容转换成原数据类型
结果:<function func at 0x000001BBFF7060D0>

四、os (文件夹 文件 路径)

import os	#os是和操作系统做交互,给操作发指令

print(os.getcwd()) 	# 获取当前文件工作的路径
os.chdir(" ") #路径切换
os.curdir  返回当前目录: ('.')  **
os.pardir 获取当前目录的父目录字符串名:('..') **

文件夹相关

os.mkdir("a2")	# 创建文件夹	a2为要创建的文件夹

os.rmdir("a2")	# 删除文件夹

os.makedirs("a1/a2/a3")	# 递归创建多级文件夹

os.removedirs("a1/a2/a3")	# 递归删除文件夹

print(os.listdir(r"路径"))	#查看当前文件下的所有内容

文件相关

os.remove(r"路径")	#删除文件,彻底删除	找不回来

os.rename()	#重命名
os.stat('path/filename')  获取文件/目录信息 **

路径相关

路径

os.path.abspath("py文件")	# 返回的是绝对路径

os.path.split(r"路径")	#将路径分割成一个路径和一个文件名

os.path.dirname(r"路径")	# 获取到父目录

os.path.basename(r"路径")	#获取文件名

os.path.join()	# 路径拼接(非常重要)

判断

os.path.exists()	#判断当前路径是否存在

os.path.isabs()	#判断是不是绝对路径

os.path.isdir()	#判断是不是文件夹

os.path.isfile()	#判断是不是文件

os.path.getsize()	#获取文件大小
os.path.getatime(path)  返回path所指向的文件或者目录的最后访问时间  **
os.path.getmtime(path) 返回path所指向的文件或者目录的最后修改时间 **
os.path.getsize(path) 返回path的大小 ***

操作系统相关(了解)

os.sep    输出操作系统特定的路径分隔符,win下为"\\",Linux下为"/" *
os.linesep 输出当前平台使用的行终止符,win下为"\t\n",Linux下为"\n"
os.pathsep 输出用于分割文件路径的字符串 win下为;,Linux下为: *
os.name 输出字符串指示当前使用平台。win->'nt'; Linux->'posix' *
# 和执行系统命令相关
os.system("bash command") 运行shell命令,直接显示 **
os.popen("bash command).read() 运行shell命令,获取执行结果 **
os.environ 获取系统环境变量 **

os.stat('path/filename') 获取文件/目录信息 的结构说明(了解)

stat 结构:
st_mode: inode 保护模式
st_ino: inode 节点号。
st_dev: inode 驻留的设备。
st_nlink: inode 的链接数。
st_uid: 所有者的用户ID。
st_gid: 所有者的组ID。
st_size: 普通文件以字节为单位的大小;包含等待某些特殊文件的数据。
st_atime: 上次访问的时间。
st_mtime: 最后一次修改的时间。
st_ctime: 由操作系统报告的"ctime"。在某些系统上(如Unix)是最新的元数据更改的时间,在其它系统上(如Windows)是创建时间(详细信息参见平台的文档)。

python软件开发规范&分文件对于后期代码的高效管理的更多相关文章

  1. [ python ] 软件开发规范

    在python开发中,我们建议采用如下规范: soft/ ├── bin # 程序执行文件目录 │   ├── __init__.py │   └── start.py # 程序开始执行脚本文件 ├─ ...

  2. Python软件开发规范

    bin  整个程序的执行路口    start.py conf 配置文件     setting.py lib   库  模块与包    common.py    sql.py core  核心逻辑  ...

  3. Python 入门之 软件开发规范

    Python 入门之 软件开发规范 1.软件开发规范 -- 分文件 (1)为什么使用软件开发规范: 当几百行--大几万行代码存在于一个py文件中时存在的问题: 不便于管理 修改 可读性差 加载速度慢 ...

  4. python 全栈开发,Day29(昨日作业讲解,模块搜索路径,编译python文件,包以及包的import和from,软件开发规范)

    一.昨日作业讲解 先来回顾一下昨日的内容 1.os模块 和操作系统交互 工作目录 文件夹 文件 操作系统命令 路径相关的 2.模块 最本质的区别 import会创建一个专属于模块的名字, 所有导入模块 ...

  5. Python模块的导入以及软件开发规范

    Python文件的两种用途 1 . 当脚本直接使用,直接当脚本运行调用即可 def func(): print("from func1") func() 2 . 当做模块被导入使用 ...

  6. Python 3 软件开发规范

    Python 3 软件开发规范 参考链接 http://www.cnblogs.com/linhaifeng/articles/6379069.html#_label14 对每个目录,文件介绍. #= ...

  7. python(37)- 软件开发规范

    软件开发规范 一.为什么要设计好目录结构? 1.可读性高: 不熟悉这个项目的代码的人,一眼就能看懂目录结构,知道程序启动脚本是哪个,测试目录在哪儿,配置文件在哪儿等等.从而非常快速的了解这个项目. 2 ...

  8. Python进阶(十)----软件开发规范, time模块, datatime模块,random模块,collection模块(python额外数据类型)

    Python进阶(十)----软件开发规范, time模块, datatime模块,random模块,collection模块(python额外数据类型) 一丶软件开发规范 六个目录: #### 对某 ...

  9. python中软件开发规范,模块,序列化随笔

    1.软件开发规范 首先: 当代码都存放在一个py文件中时会导致 1.不便于管理,修改,增加 2.可读性差 3.加载速度慢 划分文件1.启动文件(启动接口)--starts文件放bin文件里2.公共文件 ...

随机推荐

  1. 转 mysql查询结果输出到文件

    mysql查询结果输出到文件   mysql查询结果导出/输出/写入到文件 方法一:直接执行命令:mysql> select count(1) from table  into outfile ...

  2. shell编程:变量替换

    定义变量:$ var_1="I love you, Do you love me" 输出变量:$ echo $var_1 打印结果:I love you, Do you love ...

  3. oracle数据库 唯一约束的创建与删除

    1.创建索引: alter table TVEHICLE add constraint CHECK_ONLY unique (CNUMBERPLATE, CVIN, CPLATETYPE, DWQCH ...

  4. Emacs 25.1 error solved: url-http-create-request: Multibyte text in HTTP request

    Emacs 25.1 error solved: url-http-create-request: Multibyte text in HTTP request */--> code {colo ...

  5. html-body标签中相关标签 02

    今日主要内容: 列表标签 <ul>.<ol>.<dl> 表格标签 <table> 表单标签 <fom> 一.列表标签 列表标签分为三种. 1 ...

  6. [轉]Reverse a singly linked list

    Reverse a singly linked list  http://angelonotes.blogspot.tw/2011/08/reverse-singly-linked-list.html ...

  7. CentOS7 部署单节点 FastDFS

    准备 环境 系统:CentOS7.5 软件即依赖 libfatscommon FastDFS分离出的一些公用函数包 FastDFS fastdfs-nginx-module FastDFS和nginx ...

  8. 【牛客网-剑指offer】斐波拉契数列

    题目: 大家都知道斐波那契数列,现在要求输入一个整数n,请你输出斐波那契数列的第n项(从0开始,第0项为0).n<=39 知识点: 一列数:从1开始,前两项为1,从第三项开始每一项等于前两项之和 ...

  9. 如何取消IDEA的自动删除行尾空格?

    使用IDEA,添加注释的时候敲空格,总是会把行尾空格删除导致代码跑到注释行,很不爽~~ 取消这个不爽的功能:File--Settings--Editor--General--Other--Strip ...

  10. JS对象 window对象 屏幕可用高和宽度 1. screen.availWidth 属性返回访问者屏幕的宽度,以像素计,减去界面特性,比如任务栏。 2. screen.availHeight 属

    屏幕可用高和宽度 1. screen.availWidth 属性返回访问者屏幕的宽度,以像素计,减去界面特性,比如任务栏. 2. screen.availHeight 属性返回访问者屏幕的高度,以像素 ...