Python处理Excel文件实例代码

Python处理Excel文件实例代码,第1张

概述因为工作需求,需要审核一部分query内容是否有效,query储存在Excel中,文本内容为页面的Title,而页面的URL以HyperLink的格式关联到每个Cell。

因为工作需求,需要审核一部分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 xwimport urllibimport systype = 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 datawb = 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.rowcolnum = 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" % (query,col_dict.get(str(col))+str(row),cell.value,cell.hyperlink)      ## 对无效的链接所属的Cell染色,直接写入文件      cell.color = (253,218,4)@H_419_14@

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持编程小技巧。

总结

以上是内存溢出为你收集整理的Python处理Excel文件实例代码全部内容,希望文章能够帮你解决Python处理Excel文件实例代码所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/langs/1202139.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-06-04
下一篇 2022-06-04

发表评论

登录后才能评论

评论列表(0条)

保存