1.今日内容

  • 模块基础知识
  • time/datetime
  • json/picle
  • shutil
  • logging
  • 其他

2.内容回顾和补充

2.1模块(类库)

  • 内置
  • 第三方
  • 自定义

面试题:

  • 列举常用内置模块:json / time / os/ sys

2.2 定义模块

定义模块时可以把一个py文件或一个文件夹(包)当作一个模块,以方便于以后其他py文件的调用 。

对于包(文件夹)的定义

  • py2:文件见中必须有 _ _init _ _.py 。手工创建此文件即可。

    在pycharm中手工创建python package时候,默认自动会在这个文件中创建--init--.py文件。

  • py3:不需要 _ init _.py .

推荐大家以后写代码时,都要加上此文件。

2.3 模块的调用

2.3.1 示例一

# lizhongwei.py

#!/usr/bin/env python
# -*- coding:utf-8 -*- def show():
print('我司里种种') def func():
pass print(456)
# 导入模块,加载此模块中所有的值到内存。所以此时先打印出:456。后打印该代码块下面的123。
import lizhongwei print(123)
# 调用模块中的函数
lizhongwei.func()
# 导入模块
from lizhongwei import func,show
from lizhongwei import func
from lizhongwei import show
from lizhongwei import * func()#from导入方法,直接使用函数。
# 导入模块
from lizhongwei import func as f#别名法,防止func函数与现有代码中函数重名。 def func():
print(123)
f()

导入模块:

  • import 模块 使用方式:模块.函数()
  • from 模块 import 函数 使用方式:函数()
  • from 模块 import 函数 as 别名 使用方式:别名()

2.3.2 示例二

lizhong
- jd.py
- pdd.py
- tb.py
包.py
#上个代码框中的文件夹中文件,引用如下方法:
import lizhong.jd
lizhong.jd.f1()
from lizhong import jd
jd.f1()
from lizhong.jd import f1
f1()

总结

  • 模块和要执行的py文件在同一目录 且 需要 模块中的很多功能时,推荐用: import 模块
  • 其他推荐:from 模块 import 模块 用法:模块.函数()
  • 其他推荐:from 模块.模块 import 函数 用法:函数()

注意: sys.path的作用是什么?sys.path默认在py的安装目录和执行文件当前所在的目录。

1、如果要增加非py安装目录下,需要append非py安装目录。sys.path.append('path')。

然后在引用目录下的py文件就可以引用成功:如:import page

2、如果page的上级目录和执行的文件在同一个目录(lib),这样引用也可以:

from lib import page

3、如果page和执行的py文件在同一个目录下,直接引用即可。

import page

练习题

将父级目录加入sys.path中,方便后期调用此父级下的代码块。
import sys
v=sys.path
print(v)
import os
print(__file__)
print(os.path.dirname(__file__))
print(os.path.abspath(__file__))
print(os.path.dirname(os.path.dirname(os.path.abspath(__file__))))
DIR=os.path.dirname(os.path.dirname(os.path.abspath(__file__)))
sys.path.append(DIR)
print(sys.path)
===
['C:\\python\\venv', 'C:\\python', 'C:\\python\\python36\\python36.zip', 'C:\\python\\python36\\DLLs', 'C:\\python\\python36\\lib', 'C:\\python\\python36', 'C:\\python\\python36\\lib\\site-packages', 'C:\\python\\PyCharm 2019.2.2\\PyCharm 2018.2.1\\helpers\\pycharm_matplotlib_backend']
C:/python/venv/day15.py
C:/python/venv
C:\python\venv\day15.py
C:\python
['C:\\python\\venv', 'C:\\python', 'C:\\python\\python36\\python36.zip', 'C:\\python\\python36\\DLLs', 'C:\\python\\python36\\lib', 'C:\\python\\python36', 'C:\\python\\python36\\lib\\site-packages', 'C:\\python\\PyCharm 2019.2.2\\PyCharm 2018.2.1\\helpers\\pycharm_matplotlib_backend', 'C:\\python']

2.4 内置模块

  • os

  • sys

  • time

  • json

    • dumps

      • dump(v,f)#将v写入文件f中。
    • loads

      • print(load(f)),打印文件中内容。
    • 注意:

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

        v = {'k1':'alex','k2':'李杰'}
        
        import json
        val = json.dumps(v,ensure_ascii=False)#保留中文
        print(val)
      • 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()
      • 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))
  • haslib

  • random

  • getpass

  • shutil

  • copy

3. 今日内容

3.1 json和pickle

  • json,优点:所有语言通用;缺点:只能序列化基本的数据类型 list/dict/int...
  • pickle,优点:python中所有的东西都能被他序列化(socket对象);缺点:序列化的内容只有python认识。
import pickle

# #################### dumps/loads ######################
"""
v = {1,2,3,4}
val = pickle.dumps(v)#序列化出来不可读
print(val)
data = pickle.loads(val)
print(data,type(data))
""" """
#序列化函数(json做不到):
def f1():
print('f1') v1 = pickle.dumps(f1)
print(v1)
v2 = pickle.loads(v1)
v2()
""" # #################### dump/load ######################
# 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) ==================
encording后称作字节
json:得出来的是字符串
pickle:得出来的是字符串

3.2 shutil 模块

import shutil

# 删除目录
# shutil.rmtree('test') # 重命名,文件和目录都可以
# shutil.move('test','ttt') # 压缩文件
# shutil.make_archive('zzh','zip','D:\code\s21day16\lizhong') # 解压文件,有目录直接解压,无目录,则直接创建
# 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')

3.3 time&datetime

UTC/GMT:世界时间

本地时间:本地时区的时间。

3.3.1 time模块

  • time.time() ,时间戳:1970-1-1 00:00
  • time.sleep(10),等待秒数。
  • time.timezone
# https://login.wx.qq.com/cgi-bin/mmwebwx-bin/login?loginicon=true&uuid=4ZwIFHM6iw==&tip=1&r=-781028520&_=1555559189206

3.3.2 datetime模块

#!/usr/bin/env python
# -*- coding:utf-8 -*-
import time
from datetime import datetime,timezone,timedelta # ######################## 获取datetime格式时间 ##############################
"""
v1 = datetime.now() # 当前本地时间
print(v1)
tz = timezone(timedelta(hours=7)) # 当前东7区时间
v2 = datetime.now(tz)
print(v2)
v3 = datetime.utcnow() # 当前UTC时间
print(v3)
"""
print(datetime.datetime.now().strftime('%Y-%m-%d %H:%M:%S'))
# ######################## 把datetime格式转换成字符串 ##############################
# v1 = datetime.now()
# print(v1,type(v1))
# val = v1.strftime("%Y-%m-%d %H:%M:%S")
# print(val) # ######################## 字符串转成datetime ##############################
# v1 = datetime.strptime('2011-11-11','%Y-%m-%d')
# print(v1,type(v1)) # ######################## datetime时间的加减 ##############################
# v1 = datetime.strptime('2011-11-11','%Y-%m-%d')
# v2 = v1 - timedelta(days=140)
# date = v2.strftime('%Y-%m-%d')
# print(date) # ######################## 时间戳和datetime关系 ##############################
# ctime = time.time()
# print(ctime)
# v1 = datetime.fromtimestamp(ctime)
# print(v1) # v1 = datetime.now()
# val = v1.timestamp()
# print(val)

3.4异常处理

try:
val = input('请输入数字:')
num = int(val)
except Exception as e:
print('操作异常')
# import requests
#
# try:
# ret = requests.get('http://www.google.com')
# print(ret.text)
# except Exception as e:
# print('请求异常')
def func(a):
try:
return a.strip()
except Exception as e:
pass
return False v = func('alex')
if not v:
print('函数执行失败')
else:
print('结果是',v)

练习题

# 1. 写函数,函数接受一个列表,请将列表中的元素每个都 +100
def func(arg):
result = []
for item in arg:
if item.isdecimal():
result.append(int(item) + 100)
return result # 2. 写函数去,接受一个列表。列表中都是url,请访问每个地址并获取结果。
import requests
def func(url_list):
result = []
try:
for url in url_list:
response = requests.get(url)
result.append(response.text)
except Exception as e:
pass
return result def func2(url_list):
result = []
for url in url_list:
try:
response = requests.get(url)
result.append(response.text)
except Exception as e:
pass
return result func(['http://www.baidu.com','http://www.google.com','http://www.bing.com']) 异常处理结构:
try:
pass
except Exception as e:
pass

python笔记16的更多相关文章

  1. Python笔记 #16# Pandas: Operations

    10 Minutes to pandas #Stats # shift 这玩意儿有啥用??? s = pd.Series([1,5,np.nan], index=dates).shift(0) # s ...

  2. python笔记 - day5

    python笔记 - day5 参考: http://www.cnblogs.com/wupeiqi/articles/5484747.html http://www.cnblogs.com/alex ...

  3. python笔记 - day3

    python笔记 - day3 参考:http://www.cnblogs.com/wupeiqi/articles/5453708.html set特性: 1.无序 2.不重复 3.可嵌套 函数: ...

  4. python笔记之调用系统命令

    python笔记之调用系统命令 目前我使用到的python中执行cmd的方式有三种 使用os.system("cmd") 该方法在调用完shell脚本后,返回一个16位的二进制数, ...

  5. guxh的python笔记一:数据类型

    1,基本概念 1.1,数据类型 基本数据类型:字符串,数字,布尔等 引用数据类型:相对不可变(元组),可变(列表,字典,集合等) 基本数据类型存放实际值,引用数据类型存放对象的地址(即引用) ==:判 ...

  6. s21day11 python笔记

    s21day11 python笔记 一.函数小高级 函数名可以当作变量来使用 #示例一: def func(): print(123) func_list = [func, func, func] # ...

  7. s21day08 python笔记

    s21day08 python笔记 一.现阶段所有内容回顾 以后把每天的笔记直接补充到python学习 二.进制 对于计算机而言无论是文件存储 / 网络传输输入本质上都是:二进制(0101010101 ...

  8. s21day01 python笔记

    s21day01 python笔记 一.计算机基础 计算机的初步认识 用户:人 软件:QQ.浏览器等 解释器/编译器/虚拟机:java解释器.python解释器等 操作系统 硬件:CPU.内存.硬盘. ...

  9. python笔记-1(import导入、time/datetime/random/os/sys模块)

    python笔记-6(import导入.time/datetime/random/os/sys模块)   一.了解模块导入的基本知识 此部分此处不展开细说import导入,仅写几个点目前的认知即可.其 ...

随机推荐

  1. 斜率优化入门题题单$QwQ$

    其实就是这一篇的那个例题帕的大部分题目的题解就写这儿辣,,, 因为都是些基础题不想专门给写题解,,,但是又掌握得差不得不写,,, 麻油办法就写一块儿好辣$QwQ$ 当然辣比较难的我就没放进来辣$QwQ ...

  2. 洛谷$P$3293 美味 $[SCOI2016]$ 主席树

    正解:主席树 解题报告: 传送门! 挺有趣的,至少我不会$QAQ$(虽然我不会的多了去了$QAQ$ 如果没有这个所谓美味度限制可以直接线段树水过去嘛$QwQ$ 然后现在问的是个异或运算后的结果,关于异 ...

  3. CompositePattern(组合模式)-----Java/.Net

    组合模式(Composite Pattern),又叫部分整体模式,是用于把一组相似的对象当作一个单一的对象.组合模式依据树形结构来组合对象,用来表示部分以及整体层次.这种类型的设计模式属于结构型模式, ...

  4. python中的enumerate、map、filter和zip函数

    引入 python内置了很多可以供我们直接调用的函数,这些函数的效率往往都非常高.我们在自己造轮子的同时,也非常有必要了解并且正确使用python给我们提供的大量的内置函数.在前面的博客里面我已经介绍 ...

  5. 个人博客-vue-blog

    http://47.100.126.169/zmengBlog/

  6. 天梯 L2 紧急救援 (dijkstra变形+记录路径)

    L2-001 紧急救援 (25 分) 作为一个城市的应急救援队伍的负责人,你有一张特殊的全国地图.在地图上显示有多个分散的城市和一些连接城市的快速道路.每个城市的救援队数量和每一条连接两个城市的快速道 ...

  7. python文档字符串(函数使用说明)

    关键字: 函数说明.help()函数 1.效果图: 2.代码: # 文档字符串( doc str) 是 函数使用说明 # 用法: 在函数第一行写一个字符串 def fn(*nums): ''' 函数的 ...

  8. STM32动态内存分配需要注意的地方

    STM32进行动态内存分配是需要注意动态内存分配大小不要超过.S文件中设置Heap Size大小 如图所示: 0x4000 :可以分配得最大字节是16384bytes 这个地方malloc的大小超过了 ...

  9. java.sql.SQLException: connection holder is null 问题处理

    问题描述 上上个周测试的时候突然报系统异常,于是我立即查看日志,发现是一个数据库异常:java.sql.SQLException: connection holder is null我第一想到的就是可 ...

  10. 关于python列表的一些基础知识。

    因学校实验室要求,自学了python,一开始看书觉得太简单了,也没有多动手去尝试,直到看完了前八章突然想动手试试的时候,人傻了,深刻体会到了好记性不如烂笔头的道理,故整理一些python列表的操作. ...