#!/usr/bin/python
#-*-coding:gbk-*-

#Python3 标准库概览
'''
操作系统接口
os模块提供了不少与操作系统相关联的函数。
建议使用 "import os" 风格而非 "from os import *"。这样可以保证随操作系统不同而有所变化的 os.open() 不会覆盖内置函数 open()。
在使用 os 这样的大型模块时内置的 dir() 和 help() 函数非常有用
'''
import os
print(os.getcwd())

#针对日常的文件和目录管理任务,:mod:shutil 模块提供了一个易于使用的高级接口:
import shutil
shutil.copy("from", "to")
shutil.move("file", "dir")

#文件通配符
#glob模块提供了一个函数用于从目录通配符搜索中生成文件列表:
import glob
print(glob.glob("*.py"))

#命令行参数
#通用工具脚本经常调用命令行参数。这些命令行参数以链表形式存储于 sys 模块的 argv 变量
import sys
print(sys.argv)

#错误输出重定向和程序终止
#sys 还有 stdin,stdout 和 stderr 属性,即使在 stdout 被重定向时,后者也可以用于显示警告和错误信息。
import sys
sys.stderr.write("出错了")
#大多脚本的定向终止都使用 "sys.exit()"。

'''
字符串正则匹配
re模块为高级字符串处理提供了正则表达式工具。对于复杂的匹配和处理,正则表达式提供了简洁、优化的解决方案
'''
import read
re.findall(r"\bf[a-z]*", "which foot or hand fell fastest")
#如果只需要简单的功能,应该首先考虑字符串方法,因为它们非常简单,易于阅读和调试:
str1 = "tea for too"
str1.replace("too", "two")
print(str1)

#数学,math模块为浮点运算提供了对底层C函数库的访问:
import math
print(math.cos(math.pi / 4))

#random提供了生成随机数的工具。
import random
print(random.choice(["apple", "pear", "banana"]))
print(random.sameple(range(100), 10))
print(random.random())
print(random.randrange())

'''
访问 互联网
有几个模块用于访问互联网以及处理网络通信协议。其中最简单的两个是用于处理从 urls
接收的数据的 urllib.request 以及用于发送电子邮件的 smtplib:
'''
from urllib.request import urlopen
for line in urlopen("http://www.baidu.com"):
    line = line.decode("utf-8")
    if "EST" in line or "EDT" in line:
        print line
import smtplib
server = smtplib.SMTP("localhost")   #需要本地有一个在运行的邮件服务器
server.sendmail("805316824@qq.com", "hejing@yf.com")
server.quit()

'''
日期和时间
datetime模块为日期和时间处理同时提供了简单和复杂的方法。
支持日期和时间算法的同时,实现的重点放在更有效的处理和格式化输出。
该模块还支持时区处理
'''
from datetime import date
now = date.today()
print(now)
now.strftime("%m-%d-%y. %d %b %Y is a %A on the %d day of %B.")

birthday = date(2000, 1, 1)
age = now - birthday
print(age.days)

'''
数据压缩
以下模块直接支持通用的数据打包和压缩格式:zlib,gzip,bz2,zipfile,以及 tarfile
'''
import zlib
s = "ahsuidhaisjdd"
print(len(s))
z = zlib.compress(s)
print(len(z))
s = zlib.decompress(z)
print(s)
print(len(s))
print(zlib.crc32(s))

'''
性能度量
有些用户对了解解决同一问题的不同方法之间的性能差异很感兴趣。Python 提供了一个度量工具,为这些问题提供了直接答案。
例如,使用元组封装和拆封来交换元素看起来要比使用传统的方法要诱人的多,timeit 证明了现代的方法更快一些。
'''
from timeit import Timer
Timer("t = a; a = b; b = t", "a = 1; b = 2").timeit()
Timer("a, b = b, a", "a = 1; b = 2").timeit()
#相对于 timeit 的细粒度,:mod:profile 和 pstats 模块提供了针对更大代码块的时间度量工具。

'''
测试模块
开发高质量软件的方法之一是为每一个函数开发测试代码,并且在开发过程中经常进行测试
doctest模块提供了一个工具,扫描模块并根据程序中内嵌的文档字符串执行测试。
测试构造如同简单的将它的输出结果剪切并粘贴到文档字符串中。
通过用户提供的例子,它强化了文档,允许 doctest 模块确认代码的结果是否与文档一致
'''
def average(values):
    return sum(values) / len(values)
import doctest
doctest.testmod()   # 自动验证嵌入测试

#unittest模块不像 doctest模块那么容易使用,不过它可以在一个独立的文件里提供一个更全面的测试集
import unittest
class TestStatisticalFunctions(unittest.TestCase):
    def test_average(self):
        self.assertEqual(average(10,20,30), 20)
        self.assertRaises(ZeroDivisionError, average, [])
        self.assertRaises(TypeError, average, 10, 20, 30)
unittest.main()   # Calling from the command line invokes all tests

#关于urlopen的补充
##处理get请求,不传data,则为get请求
import urllib
from urllib.request import urlopen
from urllib.parse import urlencode

url = "http://www.xxxx.com/login"
data = {"username" : "admin", "password" : 123456}
req_data = urlencode(data) #将字典类型的请求数据转变为url编码
res = urlopen(url + '?' + req_data)   #通过urlopen方法访问拼接好的url
res = res.read().decode()   #read()方法是读取返回数据内容,decode是转换返回数据的bytes格式为str
print(res)

#处理post请求,如果传了data,则为post请求
import urllib
from urllib.request import urlopen
from urllib.parse import urlencode

url = "http://www.xxxx.com/login"
data = {"username" : "admin", "password" : 123456}
data = urlencode(data) #将字典类型的请求数据转变为url编码
data = data.encode("ascii")   #将url编码类型的请求数据转变为bytes类型
req_data = Request(url, data)   #将url和请求数据处理为一个Request对象,供urlopen调用
with urlopen(req_data) as res:
    res = res.read().decode()   read()方法是读取返回数据内容,decode是转换返回数据的bytes格式为str
print(res)

python系列十七:Python3 标准库概览的更多相关文章

  1. python023 Python3 标准库概览

    Python3 标准库概览 操作系统接口 os模块提供了不少与操作系统相关联的函数. >>> import os >>> os.getcwd() # 返回当前的工作 ...

  2. 吴裕雄--天生自然python学习笔记:Python3 标准库概览

    操作系统接口 os模块提供了不少与操作系统相关联的函数. >>> import os >>> os.getcwd() # 返回当前的工作目录 'C:\\Python ...

  3. Python3 标准库概览

    操作系统接口 os模块提供了不少与操作系统相关联的函数. >>> import os >>> os.getcwd() # 返回当前的工作目录 'C:\\Python ...

  4. 8.Python3标准库--数据持久存储与交换

    ''' 持久存储数据以便长期使用包括两个方面:在对象的内存中表示和存储格式之间来回转换数据,以及处理转换后数据的存储区. 标准库包含很多模块可以处理不同情况下的这两个方面 有两个模块可以将对象转换为一 ...

  5. 7.Python3标准库--文件系统

    ''' Python的标准库中包含大量工具,可以处理文件系统中的文件,构造和解析文件名,还可以检查文件内容. 处理文件的第一步是要确定处理的文件的名字.Python将文件名表示为简单的字符串,另外还提 ...

  6. 1.Python3标准库--前戏

    Python有一个很大的优势便是在于其拥有丰富的第三方库,可以解决很多很多问题.其实Python的标准库也是非常丰富的,今后我将介绍一下Python的标准库. 这个教程使用的书籍就叫做<Pyth ...

  7. Python3 标准库

    Python3标准库 更详尽:http://blog.csdn.net/jurbo/article/details/52334345 文本 string:通用字符串操作 re:正则表达式操作 diff ...

  8. 比较两个文件的异同Python3 标准库difflib 实现

    比较两个文件的异同Python3 标准库difflib 实现 对于要比较两个文件特别是配置文件的差异,这种需求很常见,如果用眼睛看,真是眼睛疼. 可以使用linux命令行工具diff a_file b ...

  9. python3标准库总结

    Python3标准库 操作系统接口 os模块提供了不少与操作系统相关联的函数. ? 1 2 3 4 5 6 >>> import os >>> os.getcwd( ...

随机推荐

  1. MySQL怎样存储IP地址

    为什么要问如何存储IP 首先就来阐明一下部分人得反问:为什么要问IP得怎样存,直接varchar类型不就得了吗? 其实做任何程序设计都要在功能实现的基础上最大限度的优化性能.而数据库设计是程序设计中不 ...

  2. printf函数对参数的计算顺序

    没想到啊,没想到: printf函数对参数的计算顺序是从右往左的! 我不禁想问一句,这么坑爹的事情,书里居然没有写过.还是我看书不仔细,没有找到?(回头,在自己翻翻那本c语言编程) 于是下面的程序结果 ...

  3. unittest最详细的解说

    转自:http://www.imooc.com/article/257230 一.什么是unittest unittest是Python单元测试框架,类似于JUnit框架. unittest中有4个重 ...

  4. mysql乐观锁和悲观锁

    在多用户环境中,在同一时间可能会有多个用户更新相同的记录,这会产生冲突.这就是著名的并发性问题. 悲观锁:假定会发生并发冲突,屏蔽一切可能违反数据完整性的操作. 乐观锁:假设不会发生并发冲突,只在提交 ...

  5. php的颜色定义表

    http://outofmemory.cn/code-snippet/1960/php-color-define-table <? /////////////////////////////// ...

  6. ant.xml

    <?xml version="1.0"?> <project name="dxcc" default="buildplugins&q ...

  7. python 的__FILE__,__LINE__功能实现

    在C语言里,__FILE__和__LINE__给调试提供了很大的方便,今晚在写PYTHON的时候想到,PYTHON是否有类似的功能实现呢? GOOGLE一番发现两个方法,试验一下下面这句:print ...

  8. hdu6058 Kanade's sum 区间第k大

    /** 题目:Kanade's sum 链接:http://acm.hdu.edu.cn/showproblem.php?pid=6058 题意:给定[1,n]的排列,定义f(l,r,k)表示区间[l ...

  9. Oracle的REGEXP_INSTR函数简单使用方法

    REGEXP_INSTR函数让你搜索一个正則表達式模式字符串. 函数使用输入字符集定义的字符进行字符串的计算. 它返回一个整数,指示開始或结束匹配的子位置.这取决于return_option參数的值. ...

  10. vmware复制虚拟机出现Error:No suitable device found:no device found for connection 'System eth0'

    vmware复制虚拟机出现Error:No suitable device found:no device found for connection 'System eth0' 废话不多说,直接给出解 ...