本人在使用groovy爬取了全国3000+城市的历史天气之后,需要把每个城市的历史天气都绘制一张Time Series表格,用来反映各地的最高温最低温温差的变化曲线。这里遇到了一个问题,每次plotly绘制完图标总会调起系统浏览器打开呈现,一旦我批量生成N多张表格时,电脑就会卡死了。在使用中文作为文件名的时候遇到了一个错误,这个错误刚好能巧妙解决这个问题。在不同编码格式的字符拼接时文件路径时,会报错,报错内容如下:

​'ascii' codec can't encode characters in position 69-70: ordinal not in range(128)​

然后程序停止运行,但是文件已经生成了。在做了异常处理后,刚好能满足需求。关于python2.7的编码问题,并不是很了解为什么出这个错。

python部分的代码如下:

#!/usr/bin/python
2# coding=utf-8
3
4from first.date import DatePlot
5import os
6from second.MysqlFission import MysqlFission
7import shutil
8import time
9
10
11class Fission:
12 x = []
13 y = []
14 z = []
15 d = []
16 def __init__(self):
17 print "欢迎使用fission类!"
18 # def __init__(self,x,y,z,d):
19 # def __init__(self,name):
20 # self.name = name
21 # print "欢迎使用fission类!"
22 def getData(self, name):
23 size = 0;
24 with open("/Users/Vicky/Documents/workspace/source_api/long/" + name + ".log") as apidata:
25 for i in apidata:
26 data = i.split("\r\n")[0].split("|")[0]
27 low = i.split("\r\n")[0].split("|")[1]
28 high = i.split("\r\n")[0].split("|")[2]
29 diff = int(high) - int(low)
30 self.x.append(data)
31 self.y.append(low)
32 self.z.append(high)
33 self.d.append(diff)
34 size += 1;
35
36 def getDataMarkLine(self, name):
37 with open("/Users/Vicky/Documents/workspace/source_api/long/" + name + ".log") as apidata:
38 for i in apidata:
39 data = i.split("\r\n")[0].split("|")
40 day = data[0]
41 time = float(data[1])
42 self.x.append(day)
43 self.y.append(time)
44 return [self.x, self.y]
45
46
47if __name__ == "__main__":
48 names = []
49 for name in names:
50 name = u"三沙"
51 sql = MysqlFission()
52 sql.getWeather(name)
53 fission = Fission()
54 fission.x = []
55 fission.y = []
56 fission.z = []
57 fission.d = []
58 fission.getData(name)
59 try:
60 DatePlot.MakePlotTwo(fission.x, name, high=fission.y, low=fission.z, diff=fission.d)
61 except BaseException:
62 print 2
63 shutil.copyfile(name + ".html", "/Users/Vicky/Desktop/w/" + name + ".html")
64 os.remove(name + ".html")
65 time.sleep(5)

下面是北京市的效果图:

python使用plotly批量生成图表_html