s21day16 python笔记

一、模块

1.1 模块的定义

  1. 模块的定义

    • 可以吧一个py文件或一个文件夹(包)当作一个模块,以便于以后其他py文件的调用
  2. 包的定义(python2与python3的区别七)
    • python2:文件夹中必须有_ _ init _ _.py文件
    • python3:不需要有_ _ init _ _.py文件
    • 建议:推荐以后写代码,无论是python2还是python3,都要加上此文件

1.2 模块分类(内置模块补充)

  1. time:时间模块
  • time.time:时间戳(从1970年到现在经历的秒数)
# https://login.wx.qq.com/cgi-bin/mmwebwx-bin/login?loginicon=true&uuid=4ZwIFHM6iw==&tip=1&r=-781028520&_=1555559189206
  • time.sleep:等待的秒数

  • time.timezone

  1. datetime:时间模块
  • datetime.now():当前本地时间

  • datetime.utcnow():当前UTC时间

import time
from datetime import datetime,timezone,timedelta
# 获取datetime格式时间
# 当前本地时间
v1 = datetime.now() 

# 当前东7区时间
tz = timezone(timedelta(hours=7))
v2 = datetime.now(tz)

# 当前UTC时间
v3 = datetime.utcnow()
print(v3)
  • 相互转换
import time
from datetime import datetime,timedelta
# 1.datetime格式和字符串的相互转换
# 把datetime格式转换成字符串:strftime
v1 = datetime.now()
val = v1.strftime("%Y-%m-%d %H:%M:%S")
# 字符串转成datetime格式:strptime
v1 = datetime.strptime('2011-11-11','%Y-%m-%d')

# 2.datetime时间的加减
v1 = datetime.strptime('2011-11-11','%Y-%m-%d')
v2 = v1 - timedelta(days=140)
# 再转换成字符串
date = v2.strftime('%Y-%m-%d')

# 3.时间戳和datetime的相互转换
# 时间戳转换成datetime格式:fromtimestamp
ctime = time.time()
v1 = datetime.fromtimestamp(ctime)
# datetime格式转换成时间戳:timestamp
v1 = datetime.now()
val = v1.timestamp()
  1. shutil
  • 用途:删除、重命名、压缩、解压等

  • shutil.rmtree(path):删除目录

# 删除目录
import shutil
shutil.rmtree(path)
  • shutil.move:重命名
# 重命名
import shutil
shutil.move('test','ttt')
  • shutil.make_archive:压缩文件
# 压缩文件
import shutil
shutil.make_archive('zzh','zip','D:\code\s21day16\lizhong')
  • shutil.unpack_archive:解压文件
# 解压文件
import shutil
shutil.unpack_archive('zzh.zip',extract_dir=r'D:\code\xxxxxx\xxxx',format='zip')
  • 示例
import os
import shutil
from datetime import datetime
ctime = datetime.now().strftime('%Y-%m-%d-%H-%M-%S')
# 1.压缩lizhongwei文件夹 zip
# 2.放到到 code 目录(默认不存在)
# 3.将文件解压到D:\x1目录中。
if not os.path.exists('code'):
    os.makedirs('code')
shutil.make_archive(os.path.join('code',ctime),'zip','D:\code\s21day16\lizhongwei')

file_path = os.path.join('code',ctime) + '.zip'
shutil.unpack_archive(file_path,r'D:\x1','zip')
  1. json
  • json.dumps()补充:

  • 字典或列表中如果有中文,序列化时,如果想保留中文显示

import json
v = {'k1':'alex','k2':'李杰'}
val = json.dumps(v,ensure_ascii = False)
  • json.dump:打开文件,序列化后,写入文件
import json
v = {'k1':'alex','k2':'李杰'}
f = open('x.txt',mode='w',encoding='utf-8')
val = json.dump(v,f)
print(val)
f.close()
  • json.load:打开文件,读取文件内容
import json
v = {'k1':'alex','k2':'李杰'}
f = open('x.txt',mode='r',encoding='utf-8')
data = json.load(f)
f.close()
print(data,type(data))
  1. pickle
  • pickle与json的区别

    • json

      • 优点:所有语言通用
      • 缺点:只能序列化基本的数据类型 list/dict 等
    • pickle
      • 优点:python中所有的东西都能被他序列化(socket对象)
      • 缺点:序列化的内容只有python认识
  • pickle.dumps:序列化
    • 序列化后的东西不可读
  • pickle.loads:反序列化
# 序列化
v = {1,2,3,4}
val = pickle.dumps(v)
print(val)

# 反序列化
data = pickle.loads(val)
print(data,type(data))
  • pickle.dump:写入文件(注意:mode='wb')

  • pickle.load:读取文件(注意:mode='rb')

# 写入文件
v = {1,2,3,4}
f = open('x.txt',mode='wb')
val = pickle.dump(v,f)
f.close()

# 读取文件
f = open('x.txt',mode='rb')
data = pickle.load(f)
f.close()
print(data)
  • 补充知识点:字节类型(bytes)
v1 = '李杰'
"""
名称:字符串类型
内部:unicode
类型:<class 'str'>
"""
v2 = v1.encode('utf-8')
"""
名称:字节类型
内部:其他编码(utf-8/gbk等)
类型:<class 'bytes'>
"""
# 注意:json序列化后是字符串类型,pickle序列化后是字节类型

1.3 模块的调用

1.模块的基本导入及调用:导入XXX.py文件

  • 方式一
# 导入模块,加载此模块中所有的值到内存。
import XXX

# 调用模块中的函数
XXX.func()
  • 方式二
# 导入XXX.py中的func和show
from XXX import func,show

# 导入XXX.py中的所有值
from XXX import *

# 调用模块中的函数
func()
  • 方式三
# 如果有重名情况,就导入时起一个别名
# 导入XXX.py中的func,并起一个别名为f
from XXX import func as f

# 调用模块中的函数
f()
  • 总结

    • 导入:import 模块,调用:模块.函数()
    • 导入:from 模块 import 函数,调用:函数()
    • 导入:from 模块 import 函数 as 别名,调用:别名()
    • 知识点:
      • as:起别名
      • *:代表全部
  1. 导入文件夹中的py文件及调用:导入YYY文件夹中的XXX.py文件
  • 方式一
# 导入模块
import YYY.XXX

# 调用模块中的函数
XXX.func()
  • 方式二
# 导入模块
from YYY import XXX

# 调用模块中的函数
XXX.func()
  • 方式三
# 导入模块
from YYY.XXX import func

# 调用模块中的函数
func()
  1. 总结
  • 模块和要执行的py文件在同一目录 且 需要 模块中的很多功能时,推荐用:

    • 导入:import 模块,调用:模块.函数()
  • 其他推荐:
    • 导入:from 模块 import 模块,调用:模块.函数()
    • 导入:from 模块.模块 import 函数,调用:函数()

s21day16 python笔记的更多相关文章

  1. Python笔记之不可不练

    如果您已经有了一定的Python编程基础,那么本文就是为您的编程能力锦上添花,如果您刚刚开始对Python有一点点兴趣,不怕,Python的重点基础知识已经总结在博文<Python笔记之不可不知 ...

  2. boost.python笔记

    boost.python笔记 标签: boost.python,python, C++ 简介 Boost.python是什么? 它是boost库的一部分,随boost一起安装,用来实现C++和Pyth ...

  3. 20.Python笔记之SqlAlchemy使用

    Date:2016-03-27 Title:20.Python笔记之SqlAlchemy使用 Tags:python Category:Python 作者:刘耀 博客:www.liuyao.me 一. ...

  4. Python笔记——类定义

    Python笔记——类定义 一.类定义: class <类名>: <语句> 类实例化后,可以使用其属性,实际上,创建一个类之后,可以通过类名访问其属性 如果直接使用类名修改其属 ...

  5. 13.python笔记之pyyaml模块

    Date:2016-03-25 Title:13.Python笔记之Pyymal模块使用 Tags:Python Category:Python 博客地址:www.liuyao.me 作者:刘耀 YA ...

  6. 8.python笔记之面向对象基础

    title: 8.Python笔记之面向对象基础 date: 2016-02-21 15:10:35 tags: Python categories: Python --- 面向对象思维导图 (来自1 ...

  7. python笔记 - day8

    python笔记 - day8 参考: http://www.cnblogs.com/wupeiqi/p/4766801.html http://www.cnblogs.com/wupeiqi/art ...

  8. python笔记 - day7-1 之面向对象编程

    python笔记 - day7-1 之面向对象编程 什么时候用面向对象: 多个函数的参数相同: 当某一些函数具有相同参数时,可以使用面向对象的方式,将参数值一次性的封装到对象,以后去对象中取值即可: ...

  9. python笔记 - day7

    python笔记 - day7 参考: http://www.cnblogs.com/wupeiqi/articles/5501365.html 面向对象,初级篇: http://www.cnblog ...

随机推荐

  1. CentOS7+Win10双系统的CentOS7启动bug

    自从安装了CentOS7系统,它的启动时间常常要三分钟以上,实在忍不了. 以下是CentOS7系统的启动记录片断: May 18 13:04:05 DESKTOP-23V3CHU kernel: XF ...

  2. 使用有序GUID:提升其在各数据库中作为主键时的性能

    原文出处:https://www.codeproject.com/articles/388157/guids-as-fast-primary-keys-under-multiple-database  ...

  3. 修改AD中PCB各层的透明度

    1.采用的Altium designer 版本为AD16: 2.进入PCB编辑页面,快捷键Ctrl+D,进入视图配置: 3.选择“透明度”,设置选中的层.对象所需的透明度:(横向可以连续选择多个对象, ...

  4. vmware安装CentOS开发环境搭建

    CentOS开发环境搭建 一.安装系统 新建虚拟机   2.选择“自定义(高级)”,并点击[下一步] 3.选择虚拟机硬件兼容性,并点击[下一步] 4.选择“稍后安装操作系统”,并点击[下一步] 5.选 ...

  5. mp4文件解析(纯c解析代码)

     参考链接:1. mp4文件格式解析 https://www.cnblogs.com/ranson7zop/p/7889272.html   2. MP4文件格式分析及分割实现(附源码) https: ...

  6. vivado封装IP

    reference: https://www.cnblogs.com/mouou/p/5851736.html   1.新建一个测试工程 工程化的设计方法是离不开工程的,第一步往往都是新建工程,后面我 ...

  7. [SCOI2005]扫雷

    我们可以发现...最开始的两个...只有两种情况...直接枚举一下...递推出结果好了... 呆码: #include<iostream> #include<cstring> ...

  8. Thread类源码解析

    源码版本:jdk8 其中的部分论证和示例代码:Java_Concurrency 类声明: Thread本身实现了Runnable接口 Runnable:任务,<java编程思想>中表示该命 ...

  9. c# 多线程的几种方式

    1.什么是线程? 进程作为操作系统执行程序的基本单位,拥有应用程序的资源,进程包含线程,进程的资源被线程共享,线程不拥有资源. 2.前台线程和后台线程的区别? 程序关闭时,后台线程直接关闭,但前台线程 ...

  10. Linux的.pid文件

    PID全称是Process Identification. PID是进程的代号,每个进程有唯一的PID编号.它是进程运行时系统随机分配的,并不代表专门的进程.在运行时PID是不会改变标识符的,但是你终 ...