我的第一个python程序之续集

简介: 上一篇博客当中我预留了很多问题没有处理,写出的代码给人感觉烂糟的,自己都不忍心看,经过同事的帮忙和自己一阵捣腾(各种优化),终于实现了所有需求。而且更重要的是我又换回了xlsxwriter模块,上次我说到这个模块不能修改数据,只适合一次性写入,这个说法没错,现在我们的逻辑思维改变一下,首先我们将产生的数据保存在一个文本中,然后创建一个新的execl文件和图表,接着读这个文本文件,再把文本中的所有数据再写入到excel表中,最后再创建图表。
上一篇博客当中我预留了很多问题没有处理,写出的代码给人感觉烂糟的,自己都不忍心看,经过同事的帮忙和自己一阵捣腾(各种优化),终于实现了所有需求。而且更重要的是我又换回了xlsxwriter模块,上次我说到这个模块不能修改数据,只适合一次性写入,这个说法没错,现在我们的逻辑思维改变一下,首先我们将产生的数据保存在一个文本中,然后创建一个新的execl文件和图表,接着读这个文本文件,再把文本中的所有数据再写入到excel表中,最后再创建图表。以前总是想着从文本里读一行然后在execl中写一行,现在是读所有行然后一次性写入。具体代码如下:

点击(此处)折叠或打开

  1. #!/usr/bin/python
  2. #coding=utf-8
  3. import os,sys
  4. import time
  5. import pycurl
  6. import xlsxwriter

  7. URL="http://www.baidu.com"
  8. c = pycurl.Curl()
  9. c.setopt(pycurl.URL, URL)
  10. c.setopt(pycurl.CONNECTTIMEOUT, 10)
  11. c.setopt(pycurl.TIMEOUT, 10)
  12. c.setopt(pycurl.NOPROGRESS, 1)
  13. c.setopt(pycurl.FORBID_REUSE, 1)
  14. c.setopt(pycurl.MAXREDIRS, 1)
  15. c.setopt(pycurl.DNS_CACHE_TIMEOUT, 30)

  16. indexfile = open(os.path.dirname(os.path.realpath(__file__))+"/content.txt","wb")

  17. try:
  18.     c.perform()
  19. except Exception,e:
  20.     print "connection error:"+str(e)
  21.     indexfile.close()

  22. NAMELOOKUP_TIME = c.getinfo(c.NAMELOOKUP_TIME)
  23. CONNECT_TIME = c.getinfo(c.CONNECT_TIME)
  24. TOTAL_TIME = c.getinfo(c.TOTAL_TIME)
  25. HTTP_CODE = c.getinfo(c.HTTP_CODE)
  26. SIZE_DOWNLOAD = c.getinfo(c.SIZE_DOWNLOAD)
  27. HEADER_SIZE = c.getinfo(c.HEADER_SIZE)
  28. SPEED_DOWNLOAD=c.getinfo(c.SPEED_DOWNLOAD)

  29. print "HTTP状态码: %s" %(HTTP_CODE)
  30. print "DNS解析时间: %.2f ms" %(NAMELOOKUP_TIME*1000)
  31. print "建立连接时间: %.2f ms" %(CONNECT_TIME*1000)
  32. print "传输结束总时间: %.2f ms" %(TOTAL_TIME*1000)
  33. print "下载数据包大小: %d bytes/s" %(SIZE_DOWNLOAD)
  34. print "HTTP头部大小: %d byte" %(HEADER_SIZE)
  35. print "平均下载速度: %d bytes/s" %(SPEED_DOWNLOAD)
  36. indexfile.close()
  37. c.close()

  38. if not os.path.exists('chart1.txt'):
  39.     file('chart1.txt','w')
  40.     print 'Successfully created directory', 'chart1.txt'

  41. f = file('chart1.txt','a')
  42. f.close()


  43. format=workbook.add_format()
  44. format.set_border(1)

  45. format_title=workbook.add_format()
  46. format_title.set_border(1)
  47. format_title.set_bg_color('#cccccc')

  48. format_title.set_align('center')
  49. format_title.set_bold()

  50. worksheet.write_row(0, 0,title,format_title)

  51. f = open('chart1.txt','r')
  52. line = 1
  53. for i in f:
  54.     head = [line]
  55.     lineList = i.split(',')
  56.     lineList = map(lambda i2:int(float(i2.replace("\n", ''))), lineList)
  57.     lineList = head + lineList
  58.     worksheet.write_row(line, 0, lineList, format)
  59.     line += 1

  60. average = [u'平均值', '=AVERAGE(B2:B' + str((line - 1)) +')', '=AVERAGE(C2:C' + str((line - 1)) +')', '=AVERAGE(D2:D' + str((line - 1)) +')', '=AVERAGE(E2:E' + str((line - 1)) +')', '=AVERAGE(F2:F' + str((line - 1)) +')', '=AVERAGE(G2:G' + str((line - 1)) +')', '=AVERAGE(H2:H' + str((line - 1)) +')']
  61. worksheet.write_row(line, 0, average, format)
  62. f.close()

  63. def chart_series(cur_row, line):
  64.     chart.add_series({
  65.         'categories': '=Sheet1!$B$1:$H$1',
  66.         'values': '=Sheet1!$B$'+cur_row+':$H$'+cur_row,
  67.         'line': {'color': 'black'},
  68.         'name': '=Sheet1!$B',
  69.     })

  70. for row in range(2, line + 1):
  71.     chart_series(str(row), line)

  72. chart.set_size({'width':876,'height':287})

  73. worksheet.insert_chart(line + 2, 0, chart)
  74. workbook.close()

实现的效果图如下,我们只要将此脚本放到cron计划任务中去执行就行啦!平均值永远在脚本最后一次运行数据的下面,图表永远在平均值下面的一格处,也就是最后一次运行数据的下面两格处。

目录
相关文章
|
3月前
|
机器学习/深度学习 数据挖掘 Python
Python编程入门——从零开始构建你的第一个程序
【10月更文挑战第39天】本文将带你走进Python的世界,通过简单易懂的语言和实际的代码示例,让你快速掌握Python的基础语法。无论你是编程新手还是想学习新语言的老手,这篇文章都能为你提供有价值的信息。我们将从变量、数据类型、控制结构等基本概念入手,逐步过渡到函数、模块等高级特性,最后通过一个综合示例来巩固所学知识。让我们一起开启Python编程之旅吧!
|
1月前
|
存储 NoSQL 数据库连接
在Python程序中实现LevelDB的海量key的分批次扫描
通过本文的步骤,您可以在Python程序中实现对LevelDB海量key的分批次扫描。这样不仅能够有效地管理大规模数据,还可以避免一次性加载过多数据到内存中,提高程序的性能和稳定性。希望这篇指南能为您的开发工作提供实用的帮助。
74 28
|
3月前
|
存储 Python
Python编程入门:打造你的第一个程序
【10月更文挑战第39天】在数字时代的浪潮中,掌握编程技能如同掌握了一门新时代的语言。本文将引导你步入Python编程的奇妙世界,从零基础出发,一步步构建你的第一个程序。我们将探索编程的基本概念,通过简单示例理解变量、数据类型和控制结构,最终实现一个简单的猜数字游戏。这不仅是一段代码的旅程,更是逻辑思维和问题解决能力的锻炼之旅。准备好了吗?让我们开始吧!
|
2月前
|
安全 API C语言
Python程序的安全逆向(关于我的OPENAI的APIkey是如何被盗的)
本文介绍了如何使用C语言编写一个简单的文件加解密程序,并讨论了如何为编译后的软件添加图标。此外,文章还探讨了Python的.pyc、.pyd等文件的原理,以及如何生成和使用.pyd文件来增强代码的安全性。通过视频和教程,作者详细讲解了生成.pyd文件的过程,并分享了逆向分析.pyd文件的方法。最后,文章提到可以通过定制Python解释器来进一步保护源代码。
87 6
|
2月前
|
IDE 程序员 开发工具
Python编程入门:打造你的第一个程序
迈出编程的第一步,就像在未知的海洋中航行。本文是你启航的指南针,带你了解Python这门语言的魅力所在,并手把手教你构建第一个属于自己的程序。从安装环境到编写代码,我们将一步步走过这段旅程。准备好了吗?让我们开始吧!
|
2月前
|
Shell 开发工具 Python
如何在vim里直接运行python程序
如何在vim里直接运行python程序
|
3月前
|
开发者 Python
使用Python实现自动化邮件通知:当长时程序运行结束时
本文介绍了如何使用Python实现自动化邮件通知功能,当长时间运行的程序完成后自动发送邮件通知。主要内容包括:项目背景、设置SMTP服务、编写邮件发送函数、连接SMTP服务器、发送邮件及异常处理等步骤。通过这些步骤,可以有效提高工作效率,避免长时间等待程序结果。
116 9
|
3月前
|
存储 人工智能 数据挖掘
Python编程入门:打造你的第一个程序
本文旨在为初学者提供Python编程的初步指导,通过介绍Python语言的基础概念、开发环境的搭建以及一个简单的代码示例,帮助读者快速入门。文章将引导你理解编程思维,学会如何编写、运行和调试Python代码,从而开启编程之旅。
78 2
|
3月前
|
Python
在Python中,`try...except`语句用于捕获和处理程序运行时的异常
在Python中,`try...except`语句用于捕获和处理程序运行时的异常
90 5
|
3月前
|
存储 Python
Python编程入门:理解基础语法与编写简单程序
本文旨在为初学者提供一个关于如何开始使用Python编程语言的指南。我们将从安装Python环境开始,逐步介绍变量、数据类型、控制结构、函数和模块等基本概念。通过实例演示和练习,读者将学会如何编写简单的Python程序,并了解如何解决常见的编程问题。文章最后将提供一些资源,以供进一步学习和实践。
80 1

热门文章

最新文章

推荐镜像

更多