首先安装pdfminer3k pip install pdfminer3k
提示这样就算安装完了
Successfully installed atomicwrites-1.1.5 attrs-18.1.0 more-itertools-4.2.0 pdfminer3k-1.3.1 pluggy-0.6.0 ply-3.11 py-1.5.4 pytest-3.6.2
开始正式的编码
准备pdf素材 我这里是准备了 笨办法学python的pdf
查看已从github下载好的文档实例
代码如下 ------- 基本都是复制文档的 上面还有很清楚的解析pdf到输出的方案图
from pdfminer.pdfparser import PDFParser, PDFDocument
from pdfminer.pdfinterp import PDFResourceManager, PDFPageInterpreter
from pdfminer.pdfdevice import PDFDevice
pf = open("D:/project/python/6-25/bbf_learn_python.pdf",'rb')
#创建与文档关联的解释器
parser = PDFParser(pf)
#pdf文档对象
doc = PDFDocument()
#链接解释器和文档对象
parser.set_document(doc)
doc.set_parser(parser)
# 文档初始化
doc.initialize("")
# pdf 资源管理器
resource = PDFResourceManager()
# 参数分析器
laparams = LAParams()
#pdf聚合器
device = PDFPageAggregator(resource, laparams=laparams)
#pdf解释器
interpreter = PDFPageInterpreter(resource, device)
# 使用文档对象得到页面的集合
for page in doc.get_pages():
# 使用解析器来读取页面
interpreter.process_page(page)
# 聚合器获得布局内容
layout = device.get_result()
for out in layout:
print(out.get_text())
读取内容如下 但是后续报错了 我找了很久没找到原因 'LTLine' object has no attribute 可能是因为翻页了 so 肯定是这样
笨办法学 Python (第三版)
欢迎阅读《笨办法学 Python》第三版。本书中译本发布于 https://learn-python-the-hard-way-zh_cn-
translation.readthedocs.org
英文原版地址为 http://learnpythonthehardway.org/book/
Contents:
(string)
4: 变量 (variable)
• 前言:笨办法更简单
• 习题
0: 准备工作
• 习题
1: 第一个程序
2: 注释和井号
• 习题
• 习题
3: 数字和数学计算
• 习题
和命名
• 习题
5: 更多的变量和打印
• 习题
6: 字符串
和文本
• 习题
7: 更多打印
• 习题
8: 打印,打印
9: 打印,打印,打印
• 习题
• 习题
10: 那是什么?
• 习题
11: 提问
• 习题
12: 提示别人
• 习题
13: 参数、解包、变量
• 习题
14: 提示和传递
• 习题
15: 读取文件
16: 读写文件
• 习题
• 习题
17: 更多文件操作
• 习题
18: 命名、变量、代码、函数
• 习题
19: 函数和变量
• 习题
20: 函数和文件
• 习题
21: 函数可以返回东西
• 习题
22: 到现在你学到了哪些东西?
23: 读代码
• 习题
• 习题
24: 更多练习
• 习题
25: 更多更多的练习
• 习题
26: 恭喜你,现在可以考试了!
• 习题
27: 记住逻辑关系
• 习题
28: 布尔表达式练习
• 习题
和 If
• 习题
• 习题
31: 作出决定
• 习题
32: 循环和列表
• 习题
• 习题
34: 访问列表的元素
• 习题
35: 分支和函数
36: 设计和调试
• 习题
• 习题
37: 复习各种符号
29: 如果 (if)
30: Else
33: While
对比pdf
图片截图
仔细看是有问题的
数据库
首先安装数据库 pip install pymysql
这里就不放数据库安装和基本查询语句,可以百度
贴个简单代码验证数据库是否连接成功
import pymysql as pmy
# 连接数据库
connect = pmy.connect('localhost','root','','test_pachong')
# 使用 cursor() 方法创建一个游标对象 cursor
cursor = connect.cursor()
# 使用 execute() 方法执行 SQL 查询
cursor.execute("SELECT VERSION()")
# 使用 fetchone() 方法获取数据.
data = cursor.fetchmany()
# data = cursor.fetchmany(size=number)
print("DATABASE VERSION:%s"% data)
# 关闭数据库连接
connect.close()
TXT
log文件其实和txt一样 这里我就用log做个处理,具体数据太多 先贴少部分 一共9万多行
Jun 24 03:32:02 localhost sshd[22201]: pam_succeed_if(sshd:auth): requirement "uid >= 1000" not met by user "root"
Jun 24 03:32:04 localhost sshd[22201]: Failed password for root from 182.100.67.120 port 61774 ssh2
Jun 24 03:32:04 localhost sshd[22201]: error: maximum authentication attempts exceeded for root from 182.100.67.120 port 61774 ssh2 [preauth]
Jun 24 03:32:04 localhost sshd[22201]: Disconnecting: Too many authentication failures [preauth]
Jun 24 03:32:04 localhost sshd[22201]: PAM 5 more authentication failures; logname= uid=0 euid=0 tty=ssh ruser= rhost=182.100.67.120 user=root
Jun 24 03:32:04 localhost sshd[22201]: PAM service(sshd) ignoring max retries; 6 > 3
Jun 24 03:32:05 localhost sshd[26484]: pam_unix(sshd:auth): authentication failure; logname= uid=0 euid=0 tty=ssh ruser= rhost=182.100.67.120 user=root
Jun 24 03:32:05 localhost sshd[26484]: pam_succeed_if(sshd:auth): requirement "uid >= 1000" not met by user "root"
Jun 24 03:32:07 localhost sshd[26484]: Failed password for root from 182.100.67.120 port 34196 ssh2
Jun 24 03:32:08 localhost sshd[26484]: pam_succeed_if(sshd:auth): requirement "uid >= 1000" not met by user "root"
Jun 24 03:32:11 localhost sshd[26484]: Failed password for root from 182.100.67.120 port 34196 ssh2
Jun 24 03:32:11 localhost sshd[26484]: pam_succeed_if(sshd:auth): requirement "uid >= 1000" not met by user "root"
Jun 24 03:32:13 localhost sshd[26484]: Failed password for root from 182.100.67.120 port 34196 ssh2
Jun 24 03:32:14 localhost sshd[26484]: pam_succeed_if(sshd:auth): requirement "uid >= 1000" not met by user "root"
Jun 24 03:32:16 localhost sshd[26484]: Failed password for root from 182.100.67.120 port 34196 ssh2
Jun 24 03:32:16 localhost sshd[26484]: pam_succeed_if(sshd:auth): requirement "uid >= 1000" not met by user "root"
Jun 24 03:32:18 localhost sshd[26484]: Failed password for root from 182.100.67.120 port 34196 ssh2
Jun 24 03:32:19 localhost sshd[26484]: pam_succeed_if(sshd:auth): requirement "uid >= 1000" not met by user "root"
Jun 24 03:32:21 localhost sshd[26484]: Failed password for root from 182.100.67.120 port 34196 ssh2
Jun 24 03:32:21 localhost sshd[26484]: error: maximum authentication attempts exceeded for root from 182.100.67.120 port 34196 ssh2 [preauth]
Jun 24 03:32:21 localhost sshd[26484]: Disconnecting: Too many authentication failures [preauth]
Jun 24 03:32:21 localhost sshd[26484]: PAM 5 more authentication failures; logname= uid=0 euid=0 tty=ssh ruser= rhost=182.100.67.120 user=root
任务(需求)如下
把访问服务器失败次数超过4次的做个统计 并显示次数(看似很简单,但我花了很久 因为正则不怎么熟悉)
需要 导入re 就是正则的包import re
结果如下 只贴一部分结果不然太多了
IP:112.85.42.53进入服务器2448次
IP:121.18.238.86进入服务器198次
IP:46.17.42.29进入服务器45次
IP:112.85.42.231进入服务器2454次
IP:217.23.14.245进入服务器86次
IP:125.39.58.58进入服务器20次
IP:58.221.72.141进入服务器113次
IP:193.201.224.208进入服务器134次
IP:58.42.228.170进入服务器6次
IP:94.73.247.125进入服务器20次
IP:115.248.207.78进入服务器6次
IP:165.227.37.14进入服务器8次
IP:115.71.1.45进入服务器11次
IP:217.61.96.4进入服务器37次
IP:118.85.194.26进入服务器12次
IP:46.17.42.33进入服务器45次
IP:112.85.42.197进入服务器1106次
IP:137.74.237.192进入服务器6次
IP:106.1.196.147进入服务器6次
IP:191.29.195.254进入服务器29次
IP:37.138.215.17进入服务器30次
IP:167.114.13.150进入服务器10次
IP:115.159.40.28进入服务器61次
IP:185.8.49.228进入服务器15次
IP:179.243.205.200进入服务器29次
IP:193.201.224.218进入服务器132次
IP:209.97.144.136进入服务器8次
IP:112.85.42.201进入服务器534次
IP:151.106.9.33进入服务器20次
IP:91.194.90.211进入服务器10次
IP:36.67.200.85进入服务器85次
IP:117.40.226.56进入服务器33次
IP:182.100.67.201进入服务器2481次
IP:42.7.26.60进入服务器1248次
今天搞得东西还挺多 很舒服 下午接着搞 接着学 加油加油