Python处理Excel文件实例代码
作者:Berne 时间:2022-02-15 23:13:01
因为工作需求,需要审核一部分query内容是否有效,query储存在Excel中,文本内容为页面的Title,而页面的URL以HyperLink的格式关联到每个Cell。
于是本能的想到用Python读取Excel文件之后进行文本分析,之后对每个链接进行一次HttpRequest,通过分析HttpResponse的内容来判断当前链接是否有效。
于是上网搜了下,发现比较主流的是用xlrd的插件,但是实际使用过程中发现,无论如何,最终获取的hyperlink_map值一直都是None,也没空去分析到底是为什么。最后经过搜索发现一个叫xlwings的Python库,可以有效使用。
xlwings:Python For Excel
具体的代码如下:
# -*- coding=utf-8 -*-
import xlwings as xw
import urllib
import sys
type = sys.getfilesystemencoding()
def get_html(url):
page = urllib.urlopen(url)
html = page.read()
return unzip(html)
## Debug的时候发现无论怎样做Decode,最后的结果都是乱码
## 后来发现是因为对应的网页做了压缩处理,所以需要对获取的网页内容手动解压缩
def unzip(data):
import gzip
import StringIO
data = StringIO.StringIO(data)
gz = gzip.GzipFile(fileobj=data)
data = gz.read()
gz.close()
return data
wb = xw.Book(r"C:\Users\hasee\Desktop\Test.xlsx")
main_data = wb.sheets["Sheet2"]
## 通过获取Last Cell来确定当前Sheet的有效行数与列数
rownum = main_data.range('A1').current_region.last_cell.row
colnum = main_data.range('A1').current_region.last_cell.column
## 定位column对应的列
col_dict = {"2":"B","3":"C","4":"D","5":"E","6":"F"}
for row in range(1, rownum + 1):
for col in range(2, colnum + 1):
query = main_data.range(row, 1).value
cell = main_data.range(row, col)
link = cell.hyperlink
html = get_html(link)
if "error-container" in html:
print "%s,%s,%s,%s" % (query, col_dict.get(str(col))+str(row), cell.value, cell.hyperlink)
## 对无效的链接所属的Cell染色,直接写入文件
cell.color = (253,218,4)
来源:http://www.cnblogs.com/chrischeng/p/7050027.html?utm_source=tuicool&utm_medium=referral
标签:Python,Excel


猜你喜欢
python代码实现扫码关注公众号登录的实战
2021-11-18 04:40:43

如何使用Python的Requests包实现模拟登陆
2022-10-07 03:12:26

IE7异常CSS 导致内存破坏漏洞
2009-11-30 12:52:00
go语言中排序sort的使用方法示例
2023-09-01 00:07:22
golang高并发限流操作 ping / telnet
2024-05-10 13:56:57
Python中使用PIPE操作Linux管道
2022-02-10 18:25:25

python函数参数(必须参数、可变参数、关键字参数)
2023-09-17 07:54:28
Python变量赋值的秘密分享
2021-10-12 11:53:04

Python基于socket实现TCP客户端和服务端
2023-09-29 15:30:05
pytorch掉坑记录:model.eval的作用说明
2023-01-07 11:52:18
PHP最常用的正则表达式
2024-05-03 15:34:38
Golang并发之RWMutex的用法详解
2024-05-09 14:52:35

python中list列表的高级函数
2021-02-24 08:21:14
python封装对象实现时间效果
2022-10-30 16:14:01

vue实现下拉菜单树
2024-05-09 15:18:39

pip已经安装好第三方库但pycharm中import时还是标红的解决方案
2022-05-25 00:50:16

详解字符串在Python内部是如何省内存的
2021-04-19 08:19:42

python标识符命名规范原理解析
2023-05-28 04:06:42
php网络安全中命令执行漏洞的产生及本质探究
2023-05-30 05:34:31
浅析javascript操作 cookie对象
2024-04-18 10:49:23