---恢复内容开始---

遇到的模块

  • NumPy:多维数组的有效操作。 高效的数学函数。

  • Matplotlib:可视化:2D和(最近)3D图

  • SciPy:大型库实现各种数值算法,例如:

    • 线性和非线性方程的解
    • 优化
    • 数值整合
  • Sympy:符号计算(解析的 Analytical)

  • Pandas:统计与数据分析(明天)

Numpy

ndarray类型

NumPy提供了一种新的数据类型:ndarray(n维数组)。

  • 与元组和列表不同,数组只能存储相同类型的对象
  • 这使得数组上的操作比列表快得多; 此外,阵列占用的内存少于列表。
  • 数组为列表索引机制提供强大的扩展。

创建ndarray

  1. np.array([2, 3, 6, 7])
  2. np.array( [2, 3, 6, 7+ij])

创建均匀间隔的数组

  1. import numpy as np
  2.  
  3. # arange:range(start, stop, step)的所有三个参数
  4. # 即起始值,结束值,步长都是可以用的 另外还有一个dtype参数,数据类型
  5. a=np.arange(5)
  6. b=np.arange(10,100,20,dtype = float)
  7. #linspace(start,stop,num)返回数字间隔均匀的样本,按区间[start,stop]计算:
  8. c=np.linspace(0.,2.5,5)

多维数组矩阵

  1. import numpy as np
  2.  
  3. a = np.array([[1, 2, 3] ,[4, 5, 6]])
  4. print(a)
  5. print(a.shape)#行,列数
  6. print(a.ndim)#维度数
  7. print(a.size)#元素个数

形状变化

  1. import numpy as np
  2.  
  3. a = np .arange(0, 20, 1) #1维
  4. b = a.reshape((4, 5)) #4行5列
  5. c = a.reshape((20, 1)) #2维
  6. d = a.reshape((-1, 4)) #-1:自动确定
  7. e = a.shape =(4, 5) #改变a的形状

Size(N,),(N,1)和(1,N)不同之处

  • Size(N, )表示数组是一维的。
  • Size(N,1)表示数组是维数为2, N列和1行。
  • Size(1,N)表示数组是维数为2, 1行和N列。

例子

  1. import numpy as np
  2.  
  3. a = np.array([1,2,3,4,5])
  4. b = a.copy ()
  5.  
  6. c1 = np.dot(np.transpose(a), b)#矩阵乘法dot
  7. print(c1)
  8. c = np.array([[1,2,3],[4,5,6],[7,8,9]])
  9. print(c)
  10. tran = c.transpose()#转置矩阵transpose
  11. print(tran)
  12.  
  13. ax = np.reshape(a, (5,1))
  14. bx = np.reshape(b, (1,5))
  15. c = np.dot(ax, bx)
  16. print(c)

填充数组

import numpy as np

a = np.zeros(3)#零填充
b = np.zeros((2, 2), complex)#complex 复数
c = np.ones((2, 3))
d = np.random.rand(2, 4)#rand: 0和1之间均匀分布的随机数
e = np.random.randn(2, 4)#randn: 均值为0,标准差为1的标准(高斯)正态分布

副本和视图

  • 采用一个NumPy数组的切片可以在原始数组中创建一个视图。 两个数组都指向相同的内存。因此,当修改视图时,原始数组也被修改:
  • 为避免修改原始数组,可以制作一个切片的副本
  1. import numpy as np
  2.  
  3. a = np.arange(5)
  4. print(a)
  5. b = a[2:];b[0] = 100
  6. print(b)
  7. print(a)
  8. c = a[2:].copy();
  9. c[0]=99
  10. print(c)
  11. print(a)

矩阵乘法

  运算符 * 表示元素乘法,而不是矩阵乘法:

  使用dot()函数进行矩阵乘法:

  1. import numpy as np
  2.  
  3. A = np.array([[1, 2],[3, 4]])
  4. print(A * A)
  5. print(np.dot(A,A))

文件操作

  • savetxt()将表保存到文本文件。
  • 其他可用的格式(参见API文档)。

  • save()将表保存为Numpy“.npy”格式的二进制文件

  • loadtxt()将以文本文件存储的表读入数组。
  • 默认情况下,loadtxt()假定列是用空格分隔的。 您可以通过修改可选的参数进行更改。 以散列(#)开头的行将被忽略。
  • 示例文本文件data.txt

    #  Year  Min temp.  Max temp.

    1990    -1.5     25.3

    1991    -3.2     21.2

  1. import numpy as np
  2.  
  3. a = np.linspace(, , )
  4. a.shape=(,)
  5. np.savetxt('myfile.txt',a)
  6. np.save('myfile',a)
  7. table = np.loadtxt("data.txt")

符号计算(Symbolic computat)

  以上只是数值计算,接下来涉及符号计算,python通过模块sysmpy来进行符号计算,类似于方程求解,积分等的显式求解。

声明一个符号变量 

  1. import sympy as sy
  2.  
  3. #声明x,y为变量
  4. x = sy.Symbol('x')
  5. y = sy.Symbol('y')
  6. a, b = sy.symbols('a b')
  7. #创建一个新符号(不是函数
  8. f = x**2 + y**2 -2*x*y + 5
  9. print(f)
  10. #自动简化
  11. g = x**2 + 2 - 2*x + x**2 -1
  12. print(g)

符号的使用1:求解方程

  1. import sympy as sy
  2.  
  3. x = sy.Symbol ('x')
  4. y = sy.Symbol('y')
  5. # 给定[-1,1] (give [-1, 1])
  6. print(sy.solve (x**2 - 1))
  7. # 无解 (no guarantee for solution)
  8. print(sy.solve(x**3 + 0.5*x**2 - 1))
  9. # 用x的表达式表示y (exepress x in terms of y)
  10. print (sy.solve(x**3 + y**2))
  11. # 错误:找不到算法 (error: no algorithm can be found)
  12. print(sy.solve(x**x + 2*x - 1))

符号的使用2:集成

  1. import sympy as sy
  2.  
  3. x = sy.Symbol('x')
  4. y = sy.Symbol( 'y')
  5. a,b = sy.symbols ( 'a b')
  6. # 单变量 single variable
  7. f = sy.sin(x) + sy.exp(x)
  8. print(sy.integrate(f, (x, a, b)))
  9. print(sy.integrate(f, (x, 1, 2)))
  10. print(sy.integrate(f, (x, 1.0,2.0)))
  11. # 多变量 multi variables
  12. g = sy.exp(x) + x * sy.sin(y)
  13. print(sy.integrate(g, (y,a,b)))

符号的使用3:分化

  1. import sympy as sy
  2.  
  3. x = sy.Symbol( 'x')
  4. y = sy.Symbol( 'y')
  5. # 单变量 (single variable)
  6. f = sy.cos(x) + x**x
  7. print(sy . diff (f , x))
  8. # 多变量 (multi variables)
  9. g = sy.cos(y) * x + sy.log(y)
  10. print(sy.diff (g, y))

---恢复内容结束---

爬虫原理:

  模拟浏览器 --> 往目标站点发送请求 --> 接收响应数据 --> 提取有用的数据 --> 保存到本地/数据库。

爬虫的全过程:
  1、发送请求 (请求库)
    - requests模块
    - selenium模块

  2、获取响应数据(服务器返回)

  3、解析并提取数据(解析库)
    - re正则
    - bs4(BeautifulSoup4)
    - Xpath

  4、保存数据(存储库)
    -MongoDB

  1. import requests
  2. import re # 正则模块
  3. # uuid.uuid4() 可以根据时间戳生成一段世界上唯一的随机字符串
  4. import uuid
  5. # 爬虫三部曲
  6. # 1、发送请求
  7. def get_page(url):
  8. response = requests.get(url)
  9. return response
  10. # 2、解析数据
  11. # 解析主页获取视频详情页ID
  12. def parse_index(text):
  13. res = re.findall('<a href="video_(.*?)"', text, re.S)
  14. #re.findall('正则匹配规则','解析文本','正则模式')
  15. # print(res)
  16. detail_url_list = []
  17. for m_id in res:
  18. # 拼接详情页url
  19. detail_url = 'https://www.pearvideo.com/video_' + m_id
  20. # print(detail_url)
  21. detail_url_list.append(detail_url)
  22. # print(detail_url_list)
  23. return detail_url_list
  24. # 解析详情页获取视频url
  25. def parse_detail(text):
  26. ''''''
  27. '''
  28. (.*?): 提取括号的内容
  29. .*?: 直接匹配
  30. <video webkit-playsinline="" playsinline="" x-webkit-airplay="" autoplay="autoplay" src="https://video.pearvideo.com/mp4/adshort/20190613/cont-1566073-14015522_adpkg-ad_hd.mp4" style="width: 100%; height: 100%;"></video>
  31.  
  32. 正则: <video.*?src="(.*?)"
  33.  
  34. # 以上是分析过程,不需要写
  35.  
  36. 正则: srcUrl="(.*?)"
  37. '''
  38. movie_url = re.findall('srcUrl="(.*?)"', text, re.S)[0]
  39. return movie_url
  40. # 3、保存数据
  41. def save_movie(movie_url):
  42. response = requests.get(movie_url)
  43. # 把视频写到本地
  44. with open(f'{uuid.uuid4()}.mp4', 'wb') as f:
  45. f.write(response.content)
  46. f.flush()
  47. if __name__ == '__main__': # main + 回车键
  48. # 1、对主页发送请求
  49. index_res = get_page(url='https://www.pearvideo.com/')
  50. # 2、对主页进行解析、获取详情页id
  51. detail_url_list = parse_index(index_res.text)
  52. # print(detail_url_list)
  53. # 3、对每个详情页url发送请求
  54. for detail_url in detail_url_list:
  55. detail_res = get_page(url=detail_url)
  56. print(detail_res.text)
  57. # 4、解析详情页获取视频url
  58. movie_url = parse_detail(detail_res.text)
  59. print(movie_url)
  60. # 5、保存视频
  61. save_movie(movie_url)

采用多线程方

  1. import requests
  2. import re#正则模块
  3. from concurrent.futures import ThreadPoolExecutor
  4. #限制50个线程
  5. pool=ThreadPoolExecutor(50)
  6.  
  7. def get_page(url):
  8. print(f"异步任务{url}")
  9. response=requests.get(url)
  10. return response
  11. def parse_index(res):
  12.  
  13. response=res.result()
  14. res = re.findall('<a href="video_(.*?)"',response.text,re.S)
  15.  
  16. for m_id in res:
  17. detail_url='https://www.pearvideo.com/video_'+m_id
  18. pool.submit(get_page,detail_url).add_done_callback(parse_detail)
  19.  
  20. def parse_detail(res):
  21. response=res.result()
  22.  
  23. movie_url=re.findall('srcUrl="(.*?)"',response.text,re.S)[0]
  24. movie_name=re.findall('<title>(.*?)<',response.text,re.S)[0]
  25. pool.submit(save_movie,movie_url,movie_name)
  26.  
  27. def save_movie(movie_url,movie_name):
  28. response=requests.get(movie_url)
  29. with open(f'{movie_name}.mp4','wb') as f:
  30. f.write(response.content)
  31. f.flush()
  32.  
  33. if __name__=='__main__':
  34.  
  35. url='https://www.pearvideo.com/'
  36.  
  37. pool.submit(get_page,url).add_done_callback(parse_index)

GET请求讲解

User-Agent
# 访问知乎发现
  请求url:
    https://www.zhihu.com/explore
  请求方式:
    GET
  请求头:
    user-agent: Mozilla/5.0 (Windows NT 10.0; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/65.0.3325.146 Safari/537.36
    cookies

  1. import requests
  2. # 请求头字典
  3. # headers = {
  4. # 'user-agent': 'Mozilla/5.0 (Windows NT 10.0; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/65.0.3325.146 Safari/537.36'
  5. # }
  6. # 在get请求内,添加user-agent
  7. # response = requests.get(url='https://www.zhihu.com/explore', headers=headers)
  8. # print(response.status_code) # 200
  9. # # print(response.text)
  10. # with open('zhihu.html', 'w', encoding='utf-8') as f:
  11. # f.write(response.text)
  12. '''
  13. params请求参数
  14. 访问百度搜查安徽工程大学url
  15. https://www.baidu.com/s?wd=安徽工程大学&pn=10第二页
  16. https://www.baidu.com/s?wd=安徽工程大学&pn=20第三页
  17. # '''
  18. from urllib.parse import urlencode
  19. # url = 'https://www.baidu.com/s?wd=%E8%94%A1%E5%BE%90%E5%9D%A4'
  20. # url = 'https://www.baidu.com/s?' + urlencode({"wd": "蔡徐坤"})
  21. url = 'https://www.baidu.com/s?'
  22. headers = {
  23. 'user-agent': 'Mozilla/5.0 (Windows NT 10.0; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/65.0.3325.146 Safari/537.36'
  24. }
  25. # print(url)
  26. # 在get方法中添加params参数
  27. # response = requests.get(url, headers=headers, params={"wd": "安徽工程大学"})
  28. response = requests.get(url, headers=headers, params={"wd": "安徽工程大学", "pn": ""})
  29. # print(response.text)
  30. with open('gongcheng2.html', 'w', encoding='utf-8') as f:
  31. f.write(response.text)

携带登录cookies破解github登录验证

请求url:https://github.com/settings/emails

请求方式:
  GET
请求头:
  User-Agen
  Cookie: 

  1. import requests
  2. # 请求url
  3. url = 'https://github.com/settings/emails'
  4. # 请求头
  5. headers = {
  6. 'user-agent': '',
  7. # 在请求头中拼接cookies
  8. # 'Cookie': ''
  9. }
  10. # github_res = requests.get(url, headers=headers)
  11. import requests
  12. cookies = {
  13. 'Cookie': ''
  14. }
  15. github_res = requests.get(url, headers=headers, cookies=cookies)
  16. print('' in github_res.text)

爬取豆瓣电影

  1. import requests
  2. import re
  3. url = 'https://movie.douban.com/top250'
  4. headers = {
  5. 'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/65.0.3325.146 Safari/537.36'
  6. }
  7. # 1、往豆瓣TOP250发送请求获取响应数据
  8. response = requests.get(url, headers=headers)
  9.  
  10. # print(response.text)
  11.  
  12. # 2、通过正则解析提取数据
  13. # 电影详情页url、图片链接、电影名称、电影评分、评价人数
  14. movie_content_list = re.findall(
  15. # 正则规则
  16. '<div class="item">.*?href="(.*?)">.*?src="(.*?)".*?<span class="title">(.*?)</span>.*?<span class="rating_num".*?>(.*?)</span>.*?<span>(.*?)人评价',
  17.  
  18. # 解析文本
  19. response.text,
  20.  
  21. # 匹配模式
  22. re.S)
  23.  
  24. for movie_content in movie_content_list:
  25. # 解压赋值每一部电影
  26. detail_url, movie_jpg, name, point, num = movie_content
  27. data = f'电影名称:{name}, 详情页url:{detail_url}, 图片url:{movie_jpg}, 评分: {point}, 评价人数: {num} \n'
  28. print(data)
  29.  
  30. # 3、保存数据,把电影信息写入文件中
  31. with open('douban.txt', 'a', encoding='utf-8') as f:
  32. f.write(data)

 爬取豆瓣TOP250

  1. import requests
  2. import re
  3. url_1 = 'https://movie.douban.com/top250?start='
  4. headers = {
  5. 'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/65.0.3325.146 Safari/537.36'
  6. }
  7.  
  8. for i in range(0,250,25):
  9. url=f'{url_1}{i}&filter='
  10.  
  11. response = requests.get(url, headers=headers)
  12. movie_content_list = re.findall(
  13. '<div class="item">.*?href="(.*?)">.*?src="(.*?)".*?<span class="title">(.*?)</span>.*?导演:(.*?)<br>.*?\n(.*?)&nbsp;/&nbsp;(.*?)&nbsp;/&nbsp;(.*?)\n.*?<span class="rating_num".*?>(.*?)</span>.*?<span>(.*?)人评价.*?class="inq">(.*?)</span>',
  14. response.text,
  15. re.S)
  16. for movie_content in movie_content_list:
  17. detail_url, movie_jpg, name, director,year,country,kind, point, num,profile = movie_content
  18. director=director.replace('&nbsp;',' ')
  19. data = f'电影名称:{name},导演:{director},{year.strip()},{country},{kind},评分: {point}, 评价人数: {num},{profile},详情页url:{detail_url}, 图片url:{movie_jpg}\n'
  20. with open('douban.txt', 'a', encoding='utf-8') as f:
  21. f.write(data)

效果图

Python Learning Day4的更多相关文章

  1. python learning Exception & Debug.py

    ''' 在程序运行的过程中,如果发生了错误,可以事先约定返回一个错误代码,这样,就可以知道是否有错,以及出错的原因.在操作系统提供的调用中,返回错误码非常常见.比如打开文件的函数open(),成功时返 ...

  2. Python Learning Paths

    Python Learning Paths Python Expert Python in Action Syntax Python objects Scalar types Operators St ...

  3. Python Learning

    这是自己之前整理的学习Python的资料,分享出来,希望能给别人一点帮助. Learning Plan Python是什么?- 对Python有基本的认识 版本区别 下载 安装 IDE 文件构造 Py ...

  4. python基础 Day4

    python Day4 1.列表 列表初识 之前的的三种str.int.bool在有的条件下不够用 str:存储少量的数据. 切片还是对其进行任何操作,获取的内容都是str类型.存储的数据单一. 列表 ...

  5. How to begin Python learning?

    如何开始Python语言学习? 1. 先了解它,Wiki百科:http://zh.wikipedia.org/zh-cn/Python 2. Python, Ruby等语言来自开源社区,社区的学法是V ...

  6. python作业day4计算器

    思路: 用循环提取最里面的括号,再进行运算 运算时利用正则表达式寻找相应的运算符 先进行乘除,再进行加减 (参考武sir和金角大王的代码) 流程图: 代码: #!/usr/bin/env python ...

  7. Experience of Python Learning Week 1

    1.The founder of python is Guido van Rossum ,he created it on Christmas in 1989, smriti of ABC langu ...

  8. python初识 - day4

    一.集合(set) 1.集合的定义 set 是一个无序的元素集合,支持并.交.差及对称差等数学运算, 但由于 set 不记录元素位置, 因此不支持索引.分片等类序列的操作. 2.集合的创建 大括号或 ...

  9. Python Learning: 03

    An inch is worth a pound of gold, an inch of gold is hard to buy an inch of time. Slice When the sca ...

随机推荐

  1. python isdigit()函数

    isdigit() 函数是作用于字符串的,用来判断字符串是否全部由数字组成. x = '123456' y = 'iloveyou123' print(x.isdigit(),y.isdigit()) ...

  2. Oracle--sqlplus--常用命令

    登陆:win+R输入sqlplus即可 如果前期没有用户可以输入sqlplus /nolog  记得sqlplus后有一个空格 --格式化命令 进行数据查询时,默认的方式排版会很乱,如果我们要解决这个 ...

  3. 抓包工具fiddler的Https证书设置

    一.工具(option)--设置(setting)-- https-- 动作(actions)-- (open windows certificate manger)-- 搜索(fiddler)删除所 ...

  4. Redis 详解 (四) redis的底层数据结构

    目录 1.演示数据类型的实现 2.简单动态字符串 3.链表 4.字典 5.跳跃表 6.整数集合 7.压缩列表 8.总结 上一篇博客我们介绍了 redis的五大数据类型详细用法,但是在 Redis 中, ...

  5. css快速浏览

    meta <meta charset="utf-8" /> <meta name="keywords" content="key1, ...

  6. 《新标准C++程序设计》3.1.4-3.2(C++学习笔记6)

    1.类型转换构造函数 (1)定义 只有一个参数,而且不是复制构造函数的构造函数,一般就可以看作是转换构造函数. 当需要的时候,编译系统会自动调用转换构造函数,建立一个无名的临时对象(或临时变量). ( ...

  7. ACM-DFS Template

    自己写的DFSTemplate: // DFS_Template.cpp : 定义控制台应用程序的入口点. // #include "stdafx.h" //DFS的思想是:一直向 ...

  8. Banner信息收集和美杜莎使用(9.26 第十二天)

    Banner信息收集 Banner信息,欢迎语,在banner信息中可以得到软件开发商.软件名称.版本.服务类型等信息,通过这些信息可以使用某些工具直接去使用相对应的exp去攻击 前提条件:需要和目标 ...

  9. 读书笔记 - js高级程序设计 - 第十章 DOM

      文档元素 是文档的最外层元素,在Html页面中,文档元素始终都是<html>元素 在xml中,任何元素都可以是文档元素 Node类型 Node.ELEMENT_NODE 元素 Node ...

  10. Q3狂揽3亿美元净利润的特斯拉会让国内电动汽车厂商喜极而泣吗?

    作为电动汽车行业的标杆,特斯拉无疑是国内电动汽车厂商发展进程中重要的参考对象.而前段时间特斯拉身上出现的产能受阻.私有化风波.马斯克卸任董事长一职等事件,着实让国产电动汽车厂商惊出一身冷汗.毕竟如果特 ...