python开发规范和(configparser、random模块)
目录结构
bin:存放程序入口,程序启动文件。
conf:存放配置文件,配置文件主要是一些全局变量,路径信息等。
core:程序核心文件,不涉及到业务逻辑。
app:存放和系统业务相关的逻辑。
db:存放系统运行所需的数据文件。
lib:存放公共组件。
log:存放日志文件。
README:软件说明文档。
README:
1、软件名称,软件的基本功能,应用范围。
2、软件运行环境,安装方法,启动方式等。
3、软件简要的使用说明(常用操作)。
4、代码目录结构说明,详细介绍各模块的功能及组织关系。
5、用于用户提交BUG,建议的邮箱。
configparser 配置文件
configparser文件由section组成,每个section下有自己独立的内容。
1、创建配置文件,并写入内容。
import configparser
conf = configparser.ConfigParser() # 创建一个配置文件对象
conf["DEFAULT"] = { # 将内容写入conf对象中
"IP":"127.0.0.1",
"NETMASK":"255.255.255.0",
"PORT:":""
}
conf["USER"] = { # 将内容写入conf对象中
"IP":"192.168.1.1",
"NETMASK":"255.255.255.0",
"GATEWAY":"192.168.1.255",
"PORT":""
}
file_write = open("service.ini",mode="a")
conf.write(file_write) # 将对象中的内容写入文件
file_write.close()
内容如下:

configparse:对象类似于字典,可以向字典一样操作对象。
2、读取配置文件:
import configparser
conf = configparser.ConfigParser() # 创建一个配置文件对象
conf.read("service.ini") # 一定要先读出来,然后才能操作
print(conf["DEFAULT"]["IP"],
conf["DEFAULT"]["NETMASK"],
conf["DEFAULT"]["PORT"])
print(conf["USER"]["IP"],
conf["USER"]["NETMASK"],
conf["USER"]["PORT"]) # 打印内容如下
127.0.0.1 255.255.255.0 = 8080
192.168.1.1 255.255.255.0 8088
3、使用for循环打印配置文件。
import configparser
conf = configparser.ConfigParser() # 创建一个配置文件对象
conf.read("service.ini") # 一定要先读出来,然后才能操作 for k in conf: # 通过循环打印配置文件所有内容
print(k,conf.items(k)) # 打印内容如下
DEFAULT [('ip', '127.0.0.1'), ('netmask', '255.255.255.0'), ('port', '= 8080')]
USER [('ip', '192.168.1.1'), ('netmask', '255.255.255.0'), ('port', ''), ('gateway', '192.168.1.255')]
4、修改配置文件。
修改配置文件后,一定要重新将数据写入文件,因为此时的数据是在内存当中,并没有写入文件,所以下次打开文件时,文件内容并没有被修改。如下操作:
import configparser
conf = configparser.ConfigParser() # 创建一个配置文件对象
conf.read("service.ini") # 一定要先读出来,然后才能操作
conf["DEFAULT"]["IP"] = "192.168.1.110" # 修改DEFAULT节下IP的内容
conf.write(open("service.ini",mode="w"))# 修改内容后一定要重新写入文件
print(conf["DEFAULT"]["IP"]) # 打印内容如下
192.168.1.110
查看文件是否被修改:

5、删除配置文件内容:默认配置文件DEFAULT是不允许删除的。
import configparser
conf = configparser.ConfigParser() # 创建一个配置文件对象
conf.read("service.ini") # 一定要先读出来,然后才能操作
conf.pop("USER") # 删除section
conf.write(open("service.ini",mode="w"))# 删除后一定要重新写入文件
删除后的内容如下:USER字节被删除。

random模块
randrange(start, stop[, step]):这个函数可以理解是从range(start, stop[, step])范围内随机返回一个数。
randint(a, b):随机返回一个整数围在a <= N <= b
random.choice(seq):从一个非空的序列中,随机返回一个元素。
random.choices(seq,k):从一个非空的序列中,随机返回k个元素的列表。
random.shuffle(x[, random]):对可迭代对象随机排序,前提是可跌对象必须是可以被更改的,如列表,集合等不能是字符串或者是元组等不可变数据类型。
random.sample(population, k):population参数是一个序列,或者是一个集合,参数k是要返回元素的数目,返回类型列表。
random.random():返回一个0.0-1.0内的随机小数。
random.uniform(a,b):随机返回一个a和b之间的小数。
下一篇:面向对象一:https://www.cnblogs.com/caesar-id/p/10498347.html
python开发规范和(configparser、random模块)的更多相关文章
- Python开发规范
背景 Python语言规范 Lint 导入 包 异常 全局变量 嵌套/局部/内部类或函数 列表推导(List Comprehensions) 默认迭代器和操作符 生成器 Lambda 函数 条件表达式 ...
- 万恶之源 - Python开发规范
开发规范 什么是开发规范?为什么要有开发规范呢? 你现在包括之前写的一些程序,所谓的'项目',都是在一个py文件下完成的,代码量撑死也就几百行,你认为没问题,挺好.但是真正的后端开发的项目,系统等,少 ...
- python学习笔记(七)- 递归、python内置函数、random模块
1.函数的不固定参数: #参数不是必填的.没有限制参数的个数.返回参数组的元组 def syz(*args): #参数组,不限制参数个数 #‘args’参数的名字可以随便命名 print(args) ...
- python(30)——【random模块】【if __name__ =='__main__'】【os模块】
一.random模块(随机模块) 1.random 常用模块介绍 import random print(random.random()) #返回[0,1)之间的随机浮点数 print(random. ...
- python标准库介绍——27 random 模块详解
==random 模块== "Anyone who considers arithmetical methods of producing random digits is, of cour ...
- (转)Python开发规范
转自:https://www.jianshu.com/p/d414e90dc953 Python风格规范 本项目包含了部分Google风格规范和PEP8规范,仅用作内部培训学习 Python风格规范 ...
- S1.2 Python开发规范指南
参考链接 Python风格规范 分号 不要在行尾加分号, 也不要用分号将两条命令放在同一行. 行长度 每行不超过80个字符 例外: 长的导入模块语句 注释里的URL 不要使用反斜杠连接行. Pytho ...
- 18 python 初学(time、random 模块)
# _author: lily # _date: 2019/1/13 import time import datetime print(help(time)) # print(time.time() ...
- Day13 Python基础之time/datetime/random模块一(十一)
time模块 import time print(help(time)) time.time() #return current time in seconds since the Epoch as ...
随机推荐
- 再见了Server对象,拥抱IHostingEnvironment服务对象(.net core)
一.绝对路径 1.获取应用程序运行当前目录Directory.GetCurrentDirectory(). System.IO命名空间中存在Directory类,提供了获取应用程序运行当前目录的静态方 ...
- influxdb使用说明
前言 influxdb是目前比较流行的时间序列数据库. 何谓时间序列数据库?什么是时间序列数据库,最简单的定义就是数据格式里包含Timestamp字段的数据,比如某一时间环境的温度,CPU的使用率等. ...
- 看懂Azure ML、Windows ML和ML.NET
最新2018微软中国人工智能大会刚刚落下帷幕,对于.NET开发者,可能早已被眼花缭乱的微软家AI体系弄晕了.我特意整理了几张图,以示区别. Azure ML提供了大量认知API服务,外加一个机器学习的 ...
- JAVA实现在线查看PDF和office文档
一个项目中要做一个在线预览附件(和百度文库差不多)的小功能点,楼主在开发过程中踩了很多坑的同时也总结了一些方法,仅供广大猿友参考,那么要实现这个小功能,目前主要是有如下3种可行的实现方式,下面先说实现 ...
- ModelFirst开发
首先介绍一下ModelFirst开发方式,什么时候才用呢!在没有数据库时,可以借助EF设计模型,然后根据模型同步完成数据库中表的创建,这就是Model First开发方式,简而言之就是先有模型再有表. ...
- 完美数据迁移-MongoDB Stream的应用
目录 一.背景介绍 二.常见方案 1. 停机迁移 2. 业务双写 3. 增量迁移 三.Change Stream 介绍 监听的目标 变更事件 四.实现增量迁移 五.后续优化 小结 附参考文档 一.背景 ...
- centos系统安装第三方源EPEL
epel没安装呗 相当于扩展型软件仓库,EPEL (Extra Packages for Enterprise Linux,企业版Linux的额外软件包) 是Fedora小组维护的一个软件仓库项目,为 ...
- 启航 - cache2go源码分析
一.概述 我们今天开始第一部分“golang技能提升”.这一块我计划分析3个项目,一个是很流行的golang源码阅读入门项目cache2go,接着是非常流行的memcache的go语言版groupca ...
- PC逆向之代码还原技术,第三讲汇编中加法的代码还原
目录 PC逆向之代码还原技术,第三讲汇编中加法的代码还原 一丶汇编简介 二丶高级代码对应汇编观看. 1.代码还原解析: 总结 PC逆向之代码还原技术,第三讲汇编中加法的代码还原 一丶汇编简介 在讲解加 ...
- 痞子衡嵌入式:并行接口NAND标准(ONFI)及SLC Raw NAND简介
大家好,我是痞子衡,是正经搞技术的痞子.今天痞子衡给大家介绍的是ONFI标准及SLC Raw NAND. NAND Flash是嵌入式世界里常见的存储器,对于嵌入式开发而言,NAND主要分为两大类:S ...