目录结构

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模块)的更多相关文章

  1. Python开发规范

    背景 Python语言规范 Lint 导入 包 异常 全局变量 嵌套/局部/内部类或函数 列表推导(List Comprehensions) 默认迭代器和操作符 生成器 Lambda 函数 条件表达式 ...

  2. 万恶之源 - Python开发规范

    开发规范 什么是开发规范?为什么要有开发规范呢? 你现在包括之前写的一些程序,所谓的'项目',都是在一个py文件下完成的,代码量撑死也就几百行,你认为没问题,挺好.但是真正的后端开发的项目,系统等,少 ...

  3. python学习笔记(七)- 递归、python内置函数、random模块

    1.函数的不固定参数: #参数不是必填的.没有限制参数的个数.返回参数组的元组 def syz(*args): #参数组,不限制参数个数 #‘args’参数的名字可以随便命名 print(args) ...

  4. python(30)——【random模块】【if __name__ =='__main__'】【os模块】

    一.random模块(随机模块) 1.random 常用模块介绍 import random print(random.random()) #返回[0,1)之间的随机浮点数 print(random. ...

  5. python标准库介绍——27 random 模块详解

    ==random 模块== "Anyone who considers arithmetical methods of producing random digits is, of cour ...

  6. (转)Python开发规范

    转自:https://www.jianshu.com/p/d414e90dc953 Python风格规范 本项目包含了部分Google风格规范和PEP8规范,仅用作内部培训学习 Python风格规范 ...

  7. S1.2 Python开发规范指南

    参考链接 Python风格规范 分号 不要在行尾加分号, 也不要用分号将两条命令放在同一行. 行长度 每行不超过80个字符 例外: 长的导入模块语句 注释里的URL 不要使用反斜杠连接行. Pytho ...

  8. 18 python 初学(time、random 模块)

    # _author: lily # _date: 2019/1/13 import time import datetime print(help(time)) # print(time.time() ...

  9. Day13 Python基础之time/datetime/random模块一(十一)

    time模块 import time print(help(time)) time.time() #return current time in seconds since the Epoch as ...

随机推荐

  1. 再见了Server对象,拥抱IHostingEnvironment服务对象(.net core)

    一.绝对路径 1.获取应用程序运行当前目录Directory.GetCurrentDirectory(). System.IO命名空间中存在Directory类,提供了获取应用程序运行当前目录的静态方 ...

  2. influxdb使用说明

    前言 influxdb是目前比较流行的时间序列数据库. 何谓时间序列数据库?什么是时间序列数据库,最简单的定义就是数据格式里包含Timestamp字段的数据,比如某一时间环境的温度,CPU的使用率等. ...

  3. 看懂Azure ML、Windows ML和ML.NET

    最新2018微软中国人工智能大会刚刚落下帷幕,对于.NET开发者,可能早已被眼花缭乱的微软家AI体系弄晕了.我特意整理了几张图,以示区别. Azure ML提供了大量认知API服务,外加一个机器学习的 ...

  4. JAVA实现在线查看PDF和office文档

    一个项目中要做一个在线预览附件(和百度文库差不多)的小功能点,楼主在开发过程中踩了很多坑的同时也总结了一些方法,仅供广大猿友参考,那么要实现这个小功能,目前主要是有如下3种可行的实现方式,下面先说实现 ...

  5. ModelFirst开发

    首先介绍一下ModelFirst开发方式,什么时候才用呢!在没有数据库时,可以借助EF设计模型,然后根据模型同步完成数据库中表的创建,这就是Model First开发方式,简而言之就是先有模型再有表. ...

  6. 完美数据迁移-MongoDB Stream的应用

    目录 一.背景介绍 二.常见方案 1. 停机迁移 2. 业务双写 3. 增量迁移 三.Change Stream 介绍 监听的目标 变更事件 四.实现增量迁移 五.后续优化 小结 附参考文档 一.背景 ...

  7. centos系统安装第三方源EPEL

    epel没安装呗 相当于扩展型软件仓库,EPEL (Extra Packages for Enterprise Linux,企业版Linux的额外软件包) 是Fedora小组维护的一个软件仓库项目,为 ...

  8. 启航 - cache2go源码分析

    一.概述 我们今天开始第一部分“golang技能提升”.这一块我计划分析3个项目,一个是很流行的golang源码阅读入门项目cache2go,接着是非常流行的memcache的go语言版groupca ...

  9. PC逆向之代码还原技术,第三讲汇编中加法的代码还原

    目录 PC逆向之代码还原技术,第三讲汇编中加法的代码还原 一丶汇编简介 二丶高级代码对应汇编观看. 1.代码还原解析: 总结 PC逆向之代码还原技术,第三讲汇编中加法的代码还原 一丶汇编简介 在讲解加 ...

  10. 痞子衡嵌入式:并行接口NAND标准(ONFI)及SLC Raw NAND简介

    大家好,我是痞子衡,是正经搞技术的痞子.今天痞子衡给大家介绍的是ONFI标准及SLC Raw NAND. NAND Flash是嵌入式世界里常见的存储器,对于嵌入式开发而言,NAND主要分为两大类:S ...