os  即操作系统
在 os 中提供了很多关于文件,文件夹,路径处理的函数
这是我们学习的重点 os.path 是os模块下专门用于处理路径相关的 python是一门跨平台语言,由于每个平台路径规则不同
需要一个模块来使得路径可以自动根据平台进行变化 path模块仅仅是对路径(字符串)进行操作 不会直接操作文件
os.path.abspath #返回一个绝对路径 把路径和最后的文件名/文件夹名单独切出来
os.path.split os.path.exists #判断路径是否存在 isabs#是否是绝对路径 原理是看第一个是不是路径分隔符 os.path.join #当前操作系统的分隔符来拼接
# import os
# print(os.getcwd()) #修改当前全部工作目录
# os.chdir('test')
# print(os.getcwd()) #.代表当前
# print(os.curdir)
#..代表上一级
# print(os.pardir) #创建多级目录 不同平台 路径分隔符不同
# os.makedirs('a\\b\\c\\') #获取当前平台的路径分隔符
# print(os.sep) #使用join拼接路径
# os.makedirs(os.sep.join(['a','b','c'])) #会先尝试查找a\b 这个路径 找到以后在里面创建c
# os.mkdir('a/b/c') #目录部位空时 无法删除 需要递归删除
# os.removedirs('a/b/c') #获取目录下的所有文件包括文件夹
# os.listdir(r'.....')
# dir=r'......'
# # li= os.listdir(dir)
# def show_file(path):
# li = os.listdir(path)
# for i in li:
# print(path+'\\'+i)
# #拼接完成路径
# # os.path.isfile(dir+'\\'+i) #判断是否是文件
# # os.path.isdir(dir+'\\'+i)#判断是否是路径
# #如果是文件夹就继续递归
# if os.path.isdir(path+'\\'+i)
# show_file(path+'\\'+i)
# show_file(dir) # os.rmdir 删除单级空目录 # os.path.getsize #获取文件大小 #直接把执行结果控制到控制台
# os.system('tasklist') #查找文件*****
# BASE_PATH=os.path.dirname(os.path.dirname(__file__))
# LOG_PATH=os.path.join(BASE_PATH)
# print(LOG_PATH) # os.path.gettime 查找文件最后修改时间
在python中json是一个模块

JSON :JavaScript Object Nation js 对象表示法
当年的HTML独领风骚
上网大多数情况下指的是打开网页
浏览器中运行的js语言
做后台服务器 必须保证你的数据是浏览器(JS)能够看懂的
js能看懂什么?就是json
json数据类型与python数据类型的对应关系
python中的格式 json格式
字符 字符 必须是双引号
数字 数字
字典 字典
列表 数组
元组 没有
集合 没有 使用jsom格式时要注意,最外层只能是一个数据 类型不限
如果你要一次性存储多个数据,需要使用容器 字典或数组 序列化
服务器端 需要根据前段的请求 从数据库获取数据 组织成前台可以识别的格式发给前台
反序列化
客户端 接受服务器返回的数据 并显示在屏幕上 主要函数:
序列化
dump
dumps
反序列化
load
loads json数据本质就是字符串
json 最大的优势在于 其实跨平台的数据交换格式,并且非常的轻量级
并且对比xml 非常轻量级
# import json
# li=['a','b','c']
# with open('DB.json','wt',encoding='utf-8')as f:
# json.dump(li,f) # li=[{'name':'wdj','sex':'male'},{'name':'lx','sex':'male'}]
# with open('DB.json', 'wt', encoding='utf-8')as f:
# json.dump(li, f)
# with open('DB.json', 'rt', encoding='utf-8')as f:
# res=json.load(f)
# print(res)
shelve模块 
  也是一个序列化模块
可以把它看做是一个自带序列化的字典
# import shelve
# s= shelve.open('new.sve')
# print(s) # # 存入数据
# s["name"] = "常委"
# s["age"] = 20
#
# print(s) # 取出数据
# s = shelve.open("new.sve")
# print(s["name"],s["age"],s["sex"])
xml模块
是什么?
可扩展标记语言
xml也是一种文档结构 也是一种序列化方式
与json不同的地方在于 xml可以定义文档的结构 例如在页面中 有页头页尾等..
语法格式:
使用标签来描述数据
<tag></tag>
通常由一堆标签组成 开始标签和结束标签
<tag/> 单标签 直接再名字后面加上斜杠结束 一个标签由三个部分组成
1.标签名
2.属性
<tag name='刘xx' age='20'></tag>
属性名称为name 值为刘xx 注意值必须放在双引号中
3.文本内容
<tag>这是文本内容</tag> 标签可以嵌套
<persons>
<p name='a'></p>
<p name='a'></p>
</persons>
标签嵌套时 关闭的顺序与打开的顺序 相反
注意:最外层必须只有一个跟标签
<info name="self" age="18" sex="woman"/> xml模块的使用
xml模块的主要功能是 解析xml 即序列化和反序列化
对于xml格式的数据 一般不会使用代码来生成 更多的是读取xml的文件内容
主要函数:
iter
find
findall
import xml.etree.ElementTree as ET

# ElementTree 文档树   用于读写文件
# Element 一个标签 # 解析某个文件
# tree = ET.parse("test.xml")
# 获取根标签
# root = tree.getroot()
# name为新加坡的country改成shanghai # res = root.iter("country")
# for i in res:
# if i.attrib.get("name") == "Singapore":
# i.set("name","shanghai") # 创建一个新标签
# new_tag = ET.Element("我是新标签",attrib={"name":"abc"})
# new_tag.text = "这是文本内容" # 将新标签添加到根标签中
# root.append(new_tag) # 写入文件
# tree.write("test2.xml",encoding="utf-8") # print(root)
# # tag 获取标签名字
# print(root.tag)
# 获取文本
# print(root.text)
# 获取属性 返回一个字典
# print(root.attrib) # 获取子标签(元素,节点)
# iter 在全文范围查找所有名字匹配的
# res = root.iter("country")
#
# print(list(res)) # res = root.iter("year")
# for i in res:
# print(i.text) # find 当前标签的子标签 并且只返回第一个
# res = root.find("country")
# print(res)
#
# # 可以一级一级往里找
# res = root.find("country").find("year")
# print(res)
# # print(res.attrib["name"]) # findall 当前标签的子标签 并且只返回所有匹配的
# res = root.findall("country")
# print(res[1].tag)
<?xml version="1.0"?>
<data>
<country name="Liechtenstein">
<rank updated="yes">2</rank>
<year>2008</year>
<gdppc>141100</gdppc>
<neighbor name="Austria" direction="E"/>
<neighbor name="Switzerland" direction="W"/>
</country>
<country name="Singapore">
<rank updated="yes">5</rank>
<year>2011</year>
<gdppc>59900</gdppc>
</country>
</data>

test.xml

												

常用模块之 os,json,shelve,xml模块的更多相关文章

  1. 常用模块(random,os,json,pickle,shelve)

    常用模块(random,os,json,pickle,shelve) random import random print(random.random()) # 0-1之间的小数 print(rand ...

  2. configparser模块,subprocess 模块,xlrd,xlwt ,xml 模块,面向对象

    1. configparser模块 2.subprocess 模块 3.xlrd,xlwt 4.xml 模块 5.面向对象 面向对象是什么? 是一种编程思想,指导你如何更好的编写代码 关注点在对象 具 ...

  3. python模块--json \ pickle \ shelve \ XML模块

    一.json模块 之前学习过的eval内置方法可以将一个字符串转成一个python对象,不过eval方法时有局限性的,对于普通的数据类型,json.loads和eval都能用,但遇到特殊类型的时候,e ...

  4. day16 常用模块 sys os json pickle

          知识点 os:和操作系统相关sys:和解释器相关 json:和操作JSON(一种数据交换格式)相关pickle:序列化 hashlib:加密算法Collections:集合类型       ...

  5. Py-时间,随机,os,sys,jsonpickle序列化,shelve,xml模块

    内置模块 1.时间模块 第一:time.time()是时间戳 时间戳默认是 从1970年到现在过的秒数,是一个很长的数值它可以做时间的计算以及显示 第二:localtime() 获取当前的时间,按元组 ...

  6. Python学习第十二课——json&pickle&XML模块&OS模块

    json模块 import json dic={'name':'hanhan'} i=8 s='hello' l=[11,22] data=json.dumps(dic) #json.dumps() ...

  7. python 模块二(os,json,pickle)

    #################################总结##################### os常用 os.makedirs('baby/安哥拉/特斯拉/黄晓明') os.mkd ...

  8. day21 pickle json shelve configpaser 模块

    1. 序列化:我们在网络传输的时候,需要我们对对象进行处理,把对象处理成方便存储和传输的格式,这个过程就叫序列化 序列化的方法不一定一样,三十目的都是为了方便储存和传输. 在python中有三种序列化 ...

  9. 函数和常用模块【day06】:xml模块(六)

    本节内容 1.简述 2.xml格式 3.xml节点操作 4.创建新的xml文件 一.简述 xml是实现不同语言或者程序之间进行数据交换的协议,跟json差不多,但是json使用起来更简单,不过,古时候 ...

随机推荐

  1. Storm概念学习系列之Blot消息处理者

    不多说,直接上干货! Bolt消息处理者 认识了消息源Spout和消息的数据存储元组Tuple,接下来了解消息的处理者Bolt.Bolt是接收Spout发出元组Tuple后处理数据的组件,所有的消息处 ...

  2. Asp.NetCore 2.2 WebApi 发布到IIS步骤及错误处理

    一.创建一个Asp.NetCore WebApi 程序(话不多说) 二.发布 三.配置IIS 程序池中选中网站的程序池 ——基本设置 浏览网站——浏览器 域名后面输入api/values 四.错误处理 ...

  3. Maven的学习资料收集--(八) 构建MyBatis项目

    在这里,写一下,怎么使用Maven构建MyBatis项目. 1. 新建一个Web项目 可以参考前面的博客 2. 修改pom.xml,添加MyBatis依赖 <project xmlns=&quo ...

  4. Maven的学习资料收集--(三)使用Maven构建Web项目

    新建Maven项目 File - New - Other 选择Maven Project 单击Next 保持默认即可单击Next 选择Archetype为 web app单击Next 输入一些必要信息 ...

  5. kafka基础一

    基本概念: 消息系统的组成由生产者,消费者以及存储系统.消费者从存储系统中读取生产者生产的消息.Kafka作为分布式的消息系统支持多个生产者多个消费者,写消息时允许多个生产者写到同一个Partitio ...

  6. agc016C - +/- Rectangle(构造 智商题)

    题意 题目链接 Sol 我的思路:直接按样例一的方法构造,若$h \times w$完全被$N \times M$包含显然无解 emm,wa了一发之后发现有反例:1 4 1 3 我的会输出[1 1 - ...

  7. spring-framework-3.0.2RELEASE之后为啥没有依赖包了?

    缘起:莫莫接到新任务要学习spring mvc,于是在网上找了个demo文档跟着一起做.这个是学习的网址: http://www.open-open.com/doc/view/a6462d9a2e2b ...

  8. centos升级3.10内核到4.4

    为了满足k8s对内核要求,默认Centos 7的内核为3.10建议升级到4.x内核 默认3.10内核升级为4.x内核 rpm -Uvh http://www.elrepo.org/elrepo-rel ...

  9. [VC]strcpy memcpy memset区别与简介

    strcpy 原型:extern char *strcpy(char *dest,char *src); 用法:#include <string.h> 功能:把src所指由NULL结束的字 ...

  10. java中list强转为map类型

    起因:读取数据库文件的测试用例,测试用例需要存放到一个map中,方便下次调用, 读取的内容返回的内容存放在一个list中,并且数据内容是key=value的形式,最开始使用切片方式,做了很多无用功,后 ...