一、Excel文档操作练习(pycharm)

sorted() 函数对所有可迭代的对象进行排序操作。

sort 与 sorted 区别:

sort 是应用在 list 上的方法,sorted 可以对所有可迭代的对象进行排序操作。

list 的 sort 方法返回的是对已经存在的列表进行操作,而内建函数 sorted 方法返回的是一个新的 list,而不是在原来的基础上进行的操作。

1、需提前在当前目录准备好excel文件(多复制几个):

2、编写python脚本

'''

员工角色: 行政

工作内容: 做员工调查问卷

工作流程: 给每个员工发送统-的问卷的模板

要求: 员工按照提供的固定模板,填写调查问卷,并且发送给行政人员

行政人员可能会受到多份格式相同而内容不同的Excel文件

处理Excel文件:手工合并多个文件内容,

比较常见的方法: 以某个文件(result.xlsx)的内容为基础,打开别的文件,复制其中需要的数据,粘贴到result.xlsx

'''

import os

import glob

import openpyxl

# 定义函数,获取指定目录下的所有Excel文档

def get_all_xlsx_files(path):

xlsx_files = glob.glob(os.path.join(path,'*.xlsx'))

sorted(xlsx_files, key=str.lower)

return xlsx_files

# 合并Excel文档的方法

def merge_xlsx_files(xlsx_files):

wb = openpyxl.load_workbook(xlsx_files[0])

ws = wb["Sheet1"]

# 已排序后的Excel文件的第一 顺序的文档作为基础,读取其他文档内容

for filename in xlsx_files[1:]:

workbook = openpyxl.load_workbook(filename)

worksheet = workbook["Sheet1"]

# 从工作表的第二行开始读取,第一行是表头,不读取。

for row in worksheet.iter_rows(min_row=2):

values = [cell.value for cell in row]

# 将读取到的单元格内容追加到第一顺序的Excel文档指定的sheet内容后面

ws.append(values)

return wb

def main():

xlsx_files = get_all_xlsx_files(os.path.basename("."))

wb = merge_xlsx_files(xlsx_files)

wb.save('result.xlsx')

if __name__ == '__main__':

main()

# 获取指定目录下的所有Excel文档

# xlsx_file = get_all_xlsx_files('.')

3、执行过后查看result.xlsx

都合并到一起了

二、python发送邮件(SMTP协议介绍)

smtplib发送邮件的步骤:

连接SMTP服务器 smtp = smtplib.SMTP('smtp.qq.com',25)

发送SMTP的“Hello”消息 smtp.ehlo() smtp.starttls()

登录到SMTP服务器 smtp.login(发送邮件的邮箱,邮箱授权码,不是邮箱密码)

发送电子邮件 smtp.send(发件人,收件人,邮件内容)

关闭SMTP服务器的连接 smtp.quit()

1、测试一下

import smtplib

# 连接SMTP服务器

smtp = smtplib.SMTP('smtp.qq.com',25)

# 发送SMTP的"Hello"消息

print(smtp.ehlo()) #不加密

print(smtp.starttls()) #加密

# 登录到SMTP服务器

print(smtp.login('2877364346@qq.com','gengfveyokhfdffe')) #绑定授权码

# 发送电子邮件 smtp.send(发件人,收件人,邮件内容)

print(smtp.sendmail('2877364346@qq.com','3552422607@qq.com','Subject:this is title\nthis is content'))

# 关闭SMTP服务器的连接

smtp.quit()

print('退出连接')

输出结果如下:

#不加密

(250, b'newxmesmtplogicsvrsza5.qq.com\nPIPELINING\nSIZE 73400320\nSTARTTLS\nAUTH LOGIN PLAIN\nAUTH=LOGIN\nMAILCOMPRESS\n8BITMIME')

#加密

(220, b'Ready to start TLS from 113.25.19.201 to newxmesmtplogicsvrsza5.qq.com.')

#绑定授权码成功

(235, b'Authentication successful')

# 发送电子邮件成功

{}

退出连接

查看成功接收的邮件:

2、较完整的发送

'''发送纯文本邮件'''

from __future__ import print_function

import smtplib

from email.mime.text import MIMEText

SMTP_SERVER = 'smtp.qq.com'

SMTP_PORT = 25

# 定义发送邮件的方法

def send_mail(user,pwd,to,subject,text):

# 构建MIMEText邮件对象(纯文本)

msg = MIMEText(text)

msg['From'] = user

msg['To'] = to

msg['Subject'] = subject

# 连接SMTP服务器

smtp = smtplib.SMTP(SMTP_SERVER,SMTP_PORT)

print("邮件服务器已连接")

try:

smtp.ehlo()

print('和服务器打招呼。。。')

smtp.starttls()

print('加密传输!')

smtp.ehlo()

print('再次打招呼。。。')

smtp.login(user,pwd)

print('登陆服务器')

smtp.sendmail(user,to,msg.as_string())

print('邮件已发送。。。')

except Exception as err:

raise SystemExit('邮件发送失败:{0}'.format(err))

finally:

smtp.quit()

def main():

send_mail('2877364346@qq.com','gengfveyokhfdffe','3552422607@qq.com','这是一封测试邮件','你好xgp!')

if __name__ == '__main__':

main()

输出结果如下:

邮件服务器已连接

和服务器打招呼。。。

加密传输!

再次打招呼。。。

登陆服务器

邮件已发送。。。

查看成功接收的邮件:

3、发送带附件的邮件

发送带附件的邮件,首先要创建MIMEMultipart()实例,然后构造附件,如果有多个附件,可依次构造,最后利用smtplib.smtp发送。

import yagmail

yag = yagmail.SMTP(user='2877364346@qq.com', password='gengfveyokhfdffexgp', host='smtp.qq.com', port=465)

content = ['yagmail测试邮件内容', '1000263.jpg']

yag.send('3552422607@qq.com', 'this is from yagmailtest email.', content)

查看成功接收的邮件:

三、网络管理

1、列出活跃的主机

在这一小节中,我们将会学习如何在shell脚本中调用ping命令得到网络上活跃的主机列表,随后,我们使用Python语言改造这个程序,以此支持并发的判断。

ping一下

(1)创建测试的网络

-bash-4.2# vim ips.txt

# 本机ip

192.168.1.80

# 本机

127.0.0.1

# 不可达的地址

192.168.2.2

(2)创建shell脚本,批量测IP是否可用

-bash-4.2# vim ping.sh

#/usr/bin/bash

for ip in $(cat ips.txt)

do

if ping $ip -c 2 &>/dev/null

then

echo "$ip 是活跃的。"

else

echo "$ip 是不可达的。"

fi

done

执行结果如下:

-bash-4.2# sh ping.sh

192.168.1.80 是活跃的。

127.0.0.1 是活跃的。

192.168.2.2 是不可达的。

(3)线程模块

Python中使用线程有两种方式:函数或者用类来包装线程对象。

函数式:调用thread模块中的start_new_thread()函数来产生新线程。语法如下:

thread.start_new_thread ( function, args[, kwargs] )

参数说明:

function - 线程函数。

args - 传递给线程函数的参数,他必须是个tuple类型。

kwargs - 可选参数。

Python通过两个标准库thread和threading提供对线程的支持。thread提供了低级别的、原始的线程以及一个简单的锁。

threading 模块提供的其他方法:

threading.currentThread(): 返回当前的线程变量。

threading.enumerate(): 返回一个包含正在运行的线程的list。正在运行指线程启动后、结束前,不包括启动前和终止后的线程。

threading.activeCount(): 返回正在运行的线程数量,与len(threading.enumerate())有相同的结果。

除了使用方法外,线程模块同样提供了Thread类来处理线程,Thread类提供了以下方法:

run(): 用以表示线程活动的方法。

start(): 启动线程活动。

join([time]): 等待至线程中止。这阻塞调用线程直至线程的join() 方法被调用中止-正常退出或者抛出未处理的异常-或者是可选的超时发生。

isAlive(): 返回线程是否活动的。

getName(): 返回线程名。

setName(): 设置线程名。

(4)创建python脚本,批量测IP是否可用

#!/usr/bin/python3

# encodig=utf-8

import os

import threading

def ping(ip):

'''测试网卡的连通性'''

res = os.system(u'ping -c 2 '+ip)

if res == 0:

print('网卡正常!')

else:

print('网卡异常!')

return res

def main():

with open('ips.txt') as f:

# 使用多线程

threads = []

lines = f.readlines()

for line in lines:

thread = threading.Thread(target=ping, args=(line,))

thread.start()

threads.append(thread)

for thr in threads:

thr.join()

if __name__ == '__main__':

main()

执行结果如下:

2、端口扫描

在Linux下,可以便用ping命令要判断一台主机是否可达。而判断一个端口是否打开可以使用telnet命令。 我们可以模仿前面小节中并行ping的例子,在Python代码中调用telnet命令判断一个端口是否打开。但是telnet命令存在一个问题,当我们telnet一个不可达的端口时,telnet需要很久才 能够超时返回,井且telnet命令没有参数控制超时时间。此外, 如果Python标准库中有相应的模块,应该尽可能地使用Python的标准库,而不是在Python代码中执行Linux命令。这一方面能够增加代码的可读性、可维护性.另一方面也能够保证程序跨平台运行。

为了使用Python编写端口扫描器,我们需要简单了解socket模块。socket模块为操作系统的socket连接提供了一个Python接口,有了socket模块,我们可以完成任何使用socket的任务。

(1)安装telnet

-bash-4.2# yum -y install telnet

测试一下

-bash-4.2# telnet 192.168.1.80 22 #测试连接,本机的22端口

Trying 192.168.1.80...

Connected to 192.168.1.80.

Escape character is '^]'.

SSH-2.0-OpenSSH_6.6.1

exit #退出连接

(2)socket模块

socket模块提供了一个工厂函数socket, socket函数会返向一个socket对象。我们可以给socket函数传递参数,以此创建不同网络协议和网络类塑的socket对象。默认情况下,socket函数会返回一个使用TCP协议的socket对象。

什么是 Socket?

Socket又称"套接字",应用程序通常通过"套接字"向网络发出请求或者应答网络请求,使主机间或者一台计算机上的进程间可以通讯。

socket()函数

Python 中,我们用 socket()函数来创建套接字,语法格式如下:

socket.socket([family[, type[, proto]]])

参数

family: 套接字家族可以使AF_UNIX或者AF_INET

type: 套接字类型可以根据是面向连接的还是非连接分为SOCK_STREAM或SOCK_DGRAM

protocol: 一般不填默认为0.

(1)如下所示:

-bash-4.2# ipython

Python 3.8.1 (default, Mar 9 2020, 12:35:12)

Type 'copyright', 'credits' or 'license' for more information

IPython 7.13.0 -- An enhanced Interactive Python. Type '?' for help.

In [1]: import socket

In [2]: s = socket.socket()

In [4]: s.connect(('47.100.98.242',80))

In [6]: s.send("GET/HTTP/1.0".encode())

Out[6]: 12

In [7]: print(s.recv(200))

b''

In [8]: s.close

Out[8]: >

在这个例子中, socketI厂函数以默认参数AF. INET和SOCK STREAM创建了一个名为s的socket对象,该对象可以在进程间进行TCP通信。创建完对象以后,我们使用connect函数连接到远程服务器的80端口,并发送一个HTTP请求到远程服务器,发送完毕之后,接收服务器响应的前200个字节。最后,调用socket对象的close方法关闭连接。

在这个例子中,我们用到了socket工厂函数、socket的connect方法、 send方法、recv 方法和close方法,这也是socket中最常使用的一些方法。

(2)如下所示

import socket

s = socket. socket()

s. connect(( '47.100.98.242' ,80))

s.send( ' http:/ /www.baidu.com/'.encode())

print(s.recv(10))

s.close()

执行结果如下

b'HTTP/1.1 4'

(3)接下来,我们就看一下如何使用简单的socket接口编写一个端口扫描器。 如下所示:

#!/usr/bin/python3

# encoding=utf-8

from socket import *

def conn_scan(host, port):

conn = socket(AF_INET, SOCK_STREAM)

try:

conn.connect((host, port))

print(host, port, '已连接')

except Exception as e:

print(host, port, '连接失败')

finally:

conn.close()

def main():

host = '47.100.98.242'

for port in range(20, 5000):

conn_scan(host, port)

if __name__ == '__main__':

main()

执行结果如下:

47.100.98.242 20 连接失败

47.100.98.242 21 已连接

47.100.98.242 22 已连接

47.100.98.242 23 连接失败

47.100.98.242 24 连接失败

较快的:

#encoding=utf-8

import telnetlib

def conn_scan(host, port):

t = telnetlib.Telnet()

try:

t.open(host, port, timeout=1)

print(host, port, '已连接')

except Exception as e:

print(host, port, '连接失败')

finally:

t.close()

def main():

host = '47.100.98.242'

for port in range(20, 26):

conn_scan(host, port)

if __name__ == '__main__':

main()

输出结果如下:

47.100.98.242 20 连接失败

47.100.98.242 21 已连接

47.100.98.242 22 已连接

47.100.98.242 23 连接失败

python运行需要网络吗_python邮件和网络的简单使用相关推荐

  1. python高级网络编程_python高级编程——网络编程(二)

    UDP 概念和介绍 UDP --- 用户数据报协议,是一个无连接的简单的面向数据报的运输层协议. UDP不提供可靠性,它只是把应用程序传给IP层的数据报发送出去,但是并 不能保证它们能到达目的地. U ...

  2. python初学者之网络爬虫_Python初学者之网络爬虫(二)

    到目前为止我新做了如下事情: 对MySql的读写操作进行了封装 编码风格遵从PEP8 爬取沃米优选网(http://video.51wom.com/)的主播信息 爬取一下网(http://www.yi ...

  3. python运行不了指令_python不是内部命令或外部命令,也不是可执行程序解决方法...

    简述 常见于新手初装python,然后忘记勾选设置环境变量(PATH),或者没有重启,然后运行教程中的python命令时出现. 有两个解决方法:1.设置环境变量,然后重启. 2.新建命令. 如果你打算 ...

  4. python运行代码不成功_python的运行时易犯错误,你中招了没?快来学习了

    小编话不多说,上干货!!欢迎分享跟多python知识,转发++关注,帮助跟多学习的程序猿!!! 1)忘记在 if , elif, else, for, while, class,def声明末尾添加 : ...

  5. python运行脚本被杀死_Python脚本被杀死

    环境 烧瓶0.10.1 SqlAlchemy 1.0.10版 Python 3.4.3 使用unittest 我已经创建了两个独立的测试,它们的目标是通过700k条记录查看数据库并进行一些字符串查找. ...

  6. python运行微软图标代码_Python读取xlsx数据生成图标代码实例

    运行结果: 程序代码如下: #将excel中的数据进行读取分析 import openpyxl import numpy as np import math import matplotlib.pyp ...

  7. python运行完不能显示图_Python Pygame无法正确显示图像

    我是Python的新手,我从Eric Matthes的" Python崩溃课程"开始学习.我正处于Pygame一章的开头,并且遵循代码,但是我加载的图像总是看起来损坏,我也不知道为 ...

  8. python运行界面英文翻译_python使用百度api翻译中英文

    python使用百度api翻译中英文 写程序取变量名的时候,常常需要翻译单词,或者将中文翻译成英语.有道词典,必应词典都很好,可是...命令行习惯了还是觉得用在cmd里面调出程序使用起来也许会更爽.于 ...

  9. python运行出现数据错误_Python运行出错情况

    1.错误内容:You must not use 8-bit bytestrings unless you use a text_factory that can interpret 8-bit byt ...

  10. python运行是哪个键_python – 如何使用回车键调用按钮命令

    在tkinter中,当按钮具有焦点时,您可以按空格键执行与该按钮关联的命令.我正在尝试按Enter键做同样的事情.我确定我过去做过这个,但我找不到代码,而我现在正在做的事情是行不通的.我在Mac上使用 ...

最新文章

  1. 一个express老系统csrf漏洞修复
  2. HiveSQL常用数据处理语句
  3. 神策数据周文君:杜蕾斯、滴露都在用的品牌数据营销三步法
  4. C#设计模式(1)——单例模式
  5. postfix 部署ssl后还是25_宝塔面板的邮局管理器Postfix无法启动解决办法
  6. 【图像超分辨率论文】BasicVSR: The Search for Essential Components in Video Super-Resolution and Beyond
  7. link标签引入.css文件(目的):适配不同屏幕
  8. 7-32 中位数 (10 分)
  9. 任老爷子退休以后,华为谁最有可能接手,为什么?
  10. FTP探测-挖掘鸡2014免费版
  11. 你可能成不了哪吒,更成不了朴树
  12. Pr:音频和视频的同步
  13. 2021年全国职业院校技能大赛获奖名单(高职组网络系统管理)
  14. leveldb的sstable-ldb解析
  15. QT HTTP接收多个数据包生成图片
  16. Unity 4.6.2 iOS 64位支持
  17. 【无标题】【思特奇杯·云上蓝桥-算法集训营】第1周
  18. Cocos2dx游戏教程(序):火爆抖音的网红口红机真能扎到口红吗?
  19. Clojure Web开发–最新技术–第2部分
  20. poi实现单元格行合并

热门文章

  1. 软考网络工程师考试大纲
  2. AIDA64测试CPU性能 AIDA64测试CPU需要多久
  3. egret牧场小游戏遇到的坑
  4. 计算机数字媒体毕业论文,数字媒体技术毕业设计(关于数字媒体技术的论文)
  5. Alexa Voice Server 实现的 Android APK 聊天机器人
  6. 消防物联网,为逆行英雄守住第一道生命线
  7. 计算机桌面图标被挡怎么办,win7电脑桌面图标被挡住怎么恢复 - 卡饭网
  8. Android Studio新手教程
  9. 世界地图可以无限放大_不敢相信!世界地图,你竟然骗了我这么多年...
  10. 利用matlab来进行路径规划,matlab路径规划系列