# 创建配置文件
import configparser
config = configparser.ConfigParser() # 相当于config = {} 空字典 config["default"] = {"ServerAliveInterval":"",
"Compression": "yes",
"CompressionLevel": ""} config['DEFAULT']['ForwardX11'] = 'yes' config['bitbucket.org'] = {}
config['bitbucket.org']['User'] = 'hg' config['topsecret.server.com'] = {}
topsecret = config['topsecret.server.com']
topsecret['Host Port'] = '' # mutates the parser
topsecret['ForwardX11'] = 'no' # same here with open("example.ini","w") as f:
config.write(f)
# 增删改配置文件
import configparser config = configparser.ConfigParser() config.read("example.ini") # 读出来 print(config.sections()) # ['bitbucket.org', 'topsecret.server.com'] print(config["bitbucket.org"]["User"]) # hg defalut 的信息也会被遍历出来
for key in config["bitbucket.org"]:
print(key) # ['user', 'serveraliveinterval', 'compression', 'compressionlevel', 'forwardx11']
print(config.options("bitbucket.org"))
# [('serveraliveinterval', '45'), ('compression', 'yes'), ('compressionlevel', '9'), ('forwardx11', 'yes'), ('user', 'hg')]
print(config.items("bitbucket.org"))
# yes
print(config.get("bitbucket.org", "compression")) # config.add_section("yun") # 生成新的块
# config.set("yun", "name", "alex") # 给新的块设置值 # config.remove_section("topsecret.server.com") # 删除块
# config.remove_option("bitbucket.org", "user") # 删除键值 # config.write(open("i.cfg", "w")) # 重新生成配置文件

os模块:

 # os模块________________________
print(os.getcwd()) # 当前工作目录
os.chdir("tmp") # 改变当前工作目录
print(os.getcwd()) # os.makedirs("dirname1/dirname2") # 建多个
# os.removedirs("dirname1/dirname2") # 删除空目录(如果不为空不删除)
# print(os.mkdir("t4.py")) #创建单个文件夹
# print(os.rmdir("t4.py")) # 删除单个目录,目录必须为空
# print(os.remove("__init__.py")) # 删除一个文件
# print(os.rename("test.py", "test2.py")) # 修改文件名 ("oldname","newname") print(os.listdir()) # 工作目录下载所有文件 print(os.stat("test.py")) # 文件创建以及其他一系列的信息
print(os.sep) # 当前操作系统的路径分隔符\
print(os.linesep) # window \t\n linux\n
print(os.pathsep) # ; 分割文件路径 linux用:(冒号)
# print(os.system("dir")) # 执行命令 print(os.path.split("test/file.py")) # 路径分割
print(os.path.dirname("test/file.py")) # 拿到上级目录
print(os.path.basename("test/file.py")) # 拿到文件名 # 下面是用来是判断绝对路径
print(os.path.exists(r"Users\lzh\PycharmProjects\day05"))
print(os.path.exists(r"C:\Users\lzh\PycharmProjects\day05\t1.py"))
print(os.path.isabs(r"C:\Users\lzh\PycharmProjects\day05\t1.py")) # 是否是绝对路径
print(os.path.isfile(r"C:\Users\lzh\PycharmProjects\day05\t1.py"))
print(os.path.isdir(r"C:\Users\lzh\PycharmProjects\day05"))
print(os.path.getatime(r"C:\Users\lzh\PycharmProjects\day05")) # 最后的存取时间
t1 = os.path.getatime(r"C:\Users\lzh\PycharmProjects\day05")
print(os.path.getmtime(r"C:\Users\lzh\PycharmProjects\day05")) # 最后修改时间
print(os.environ)

random模块:

 # random模块______________________

 import random
print("_____________________")
ret = random.random() # 0.7300862907438088
print(ret)
print(random.randint(1, 3)) # [1, 3] 之间的随机整数
print(random.randrange(1, 3)) # [1,3)
print(random.choice([1, 3, 4])) # 随机选取
print(random.sample([1, 2, 3, 4], 2)) # [2, 1]
print(random.uniform(1, 4)) # (1, 4)之间的浮点数
print(random.shuffle([1, 2, 3, 4, 5])) # 打乱可迭代对象中的顺序 # 验证码
def v_code():
ret = ""
for i in range(5):
num = random.randint(0, 9)
alf = random.randint(65, 122)
s = str(random.choice([num, chr(alf)])) # 相同的概率拿到
ret += s
return ret
print(v_code())
# json模块(数据交换)
dict = '{"name":"alex"}'
f = open("hello", "w")
f.write(dict) # f_read = open("hello", 'r')
# data = f_read.read()
# print(type(data))
# data = eval(data)
# print(data["name"]) import json
f = open("hello", "w")
dict = {"name": "alex"}
print(json.dumps(dict))
dict = json.dumps(dict) # 等价于json.dump(dict, f)
f.write(dict) f_read = open("hello", 'r')
json.loads(f_read.read()) # 等价于json.load(f_read)
# 文件操作 # pickle模块
import pickle
j = pickle.dumps(dict)
print(type(j)) # 字节 f = open("序列化对象——pickle", 'wb')
f.write(j) # 等价于pickle.dump(dic, f# )
f.close() f_read = open("序列化对象——pickle", 'rb')
data = pickle.loads(f_read.read()) # 等价于 pickle.load(f) # shelve模块
import shelve f = shelve.open(r"shelve") # f["info"] = {"name": "alex3"}
# f["info2"] = {"name": "alex2", "age", : }
# f["info"] = {"name": "alex1", "age", : , "gender": "男"} # f.close() print(f.get("info")["name"])

json相关模块

import sys
import time a = 1
if a == 1:
print("a==1") print(sys.platform)
print(sys.argv)
# command = sys.argv[1]
# path = sys.argv[2] # if command == "post":
# pass
# elif command == "get":
# pass # for i in range(100):
# sys.stdout.write("#")
# time.sleep(0.1)
# sys.stdout.flush()
print(sys.path)
print(sys.version)
# print(sys.exit(1))

sys

18.configparser模块的更多相关文章

  1. 小白的Python之路 day5 configparser模块的特点和用法

    configparser模块的特点和用法 一.概述 主要用于生成和修改常见配置文件,当前模块的名称在 python 3.x 版本中变更为 configparser.在python2.x版本中为Conf ...

  2. Pyhton之subprocess模块和configparser模块

    一.subprocess模式 # import os # while True: # cmd=input('>>').strip() # if not cmd:continue # if ...

  3. 函数和常用模块【day06】:configparser模块(七)

    本节内容 1.简述 2.配置文件格式 3.创建配置文件 4.读取配置文件 5.增删该查语法 一.简述 在很多情况下,我们都需要修改配置文件,但是,有些配置文件,如mysql数据库的配置文件怎么修改呢? ...

  4. 十八. Python基础(18)常用模块

    十八. Python基础(18)常用模块 1 ● 常用模块及其用途 collections模块: 一些扩展的数据类型→Counter, deque, defaultdict, namedtuple, ...

  5. Python之路(第十八篇)shutil 模块、zipfile模块、configparser模块

    一.shutil 模块 1.shutil.copyfileobj(fsrc, fdst[, length]) 将文件内容拷贝到另一个文件中,需要打开文件 import shutil shutil.co ...

  6. (转)python的ConfigParser模块

    原文:https://blog.csdn.net/miner_k/article/details/77857292 如何使用Python3读写INI配置文件-------https://blog.cs ...

  7. Python 自学基础(四)——time模块,random模块,sys模块,os模块,loggin模块,json模块,hashlib模块,configparser模块,pickle模块,正则

    时间模块 import time print(time.time()) # 当前时间戳 # time.sleep(1) # 时间延迟1秒 print(time.clock()) # CPU执行时间 p ...

  8. Python - configParser模块学习

    configParser 模块用于操作配置文件 注:Parser汉译为“解析”之意. 配置文件的格式与windows ini文件类似,可以包含一个或多个节(section),每个节可以有多个参数(键= ...

  9. configparser模块读写ini配置文件

    在自动化测试过程中,为了提高脚本的可读性和降低维护成本,将一些通用信息写入配置文件,将重复使用的方法写成公共模块进行封装,使用时候直接调用即可. 这篇博客,介绍下python中利用configpars ...

随机推荐

  1. POP与OOP编程模式对比

    面向过程:(procedure oriented programming 即:POP) 代表:C/C++ 向过程程序设计,它是以功能为中心来进行思考和组织的一种编程方式,强调的是系统的数据被加工和处理 ...

  2. Hadoop系列读书笔记

    <Hadoop应用架构>是Orilley旗下精品系列的图书 Hadoop序列化 Thrift 不支持内部压缩 不能分片 缺少MapReduce的原生支持 Protocol Buffers ...

  3. linux 在线安装jdk

    1. yum -y list java* 2.yum -y install java-1.8.0-openjdk*

  4. IDEA Git回退到指定历史版本

    1.找到要回退的版本号(右击项目--> Git --> Show History -->选中要回退的版本-->Copy Revision Number): 2.打开idea的T ...

  5. 测试基础_<一>

    1: 过程决定质量, 测试过程贯穿整个软件开发声明周期; 2: 测试过程和开发过程在整个开发周期相辅相成; 3: 测试过程是对整个开发过程的验证, 二者互相依赖 4: 测试过程是整个测试活动中一个至关 ...

  6. 协程+IO切换+小爬虫

    from gevent import monkeymonkey.patch_all() import geventimport requests def f1(url): print(f'GET:{u ...

  7. Django项目运行端口被占用

    error:以一种访问权限不允许的方式做了一个访问套接字的尝试,是8000端口被其他程序占用了,杀掉占用的程序就可以 (1)查找哪个进程占用了8000端口 `E:\sign_system\guest& ...

  8. spark教程(四)-SparkContext 和 RDD 算子

    SparkContext SparkContext 是在 spark 库中定义的一个类,作为 spark 库的入口点: 它表示连接到 spark,在进行 spark 操作之前必须先创建一个 Spark ...

  9. Mysql8.0安装与配置

    最近公司在开发项目时用到了mySql8.0版本,总结出了安装步骤,供需要的开发人员来参考 安装mySql8.0的步骤: 1.先去官网下载mySql8.0版本的安装包 一. 点击:https://dev ...

  10. js之运算符其它运算符(三元运算符,逗号运算符,void运算符,typeof,delete运算符)

    Javascript支持很多其它的运算符,具体如下: 一.条件运算符(?:) 条件运算符是Javascript中唯一的三个操作数的三元运算符,有时会直接称做是“三元运算符”. 基本格式:conditi ...