天天看點

Python 腳本學習筆記(四) 定制業務品質報表

一、使用XlsxWriter子產品生成Excel表格

安裝XlsxWriter子產品

pip2.7 install xlsxwriter

常用方法說明:

Workbook(filename [ options ])用于建立一個workbook對象

建立一個Excel檔案

workbook = xlsxwriter.Workbook('chart.xlsx') 

add_worksheet(sheetname)用于添加一個工作表,空号中可以指定工作表名稱,預設為Sheet1

建立一個工作表對象

worksheet = workbook.add_worksheet()

add_format([properties]) 用于建立一個新的格式對象,參數[properties]為指定一個格式屬性的字典如:

bold = workbook.add_format( { 'bold' : True } )

也可以通過Format methods完成格式的設定如:

bold = workbook.add_format()

bold.set_bold( )

worksheet.write(row,column,'data') 用于寫入資料到指定位置的單元格row,column,坐标索引的起始位置為0

如果用坐标表示位置的話比如(2,0) 就是 (A3);

這就是表示在A1位置寫入'hello'

worksheet.write( 0 , 0 'hello' )

set_row ( row,height,cell_format,options ) 用于設定行單元格的屬性,row為指定位置,height設定行高機關像素,cell_format指定定義好的格式對象調用,options設定行hidden(隐藏)、level(組合分級)、collapsed(折疊)操作示例如下:

設定第1行單元格高度為40像素,并調用格式cell_format 。

worksheet.set_row( 0,40,cell_format ) 

隐藏第2行單元格

worksheet.set_row(1,None,None,{ 'hidden': True })

set_column(first_col,last_col,width,cell_format,options) 用于設定一列或多列單元格屬性

設定0到1(即A到B)列單元格寬度為10像素,并調用加粗格式。

worksheet.set_column( 0,1,bold ) 

設定C到D列單元格寬度為20像素

worksheet.set_column( C:D,20 ) 

隐藏E到G列單元格

worksheet.set_column( E:G,None,None,{ 'hidden' : 1} ) 

insert_image(row,col,image,[options]) 用于插入圖檔到指定的單元格

插入圖檔指定圖檔超連結

worksheet.insert_image('B5',' img/he.jpg ',{'url':'http://python.org'} )

add_chart(type:圖表類型) 用于建立圖表對象

圖表樣式:area面積樣式、bar條形樣式、column柱形樣式、line線條樣式、pie餅圖樣式、scatter散點樣式、stock股票樣式、radar雷達樣式;

建立一個column柱形圖表

chart = workbook.add_chart({ type,'column' }) 

在A5單元格插入圖表

worksheet.insert_chart( 'A5',chart ) 

chart.add_series( )用于添加一個資料系列到圖表

常用的三個選項:categories作為設定圖表類别标簽範圍,values為設定圖示資料範圍,line為設定圖表線條屬性。

chart.add_series({

    'categories' : '=Sheet1!$A$1:$A$5',

    'values' : '=Sheet1!$B$1:$B$5',

    'line' : { 'color' : 'red' },

})

定制自動化業務流量報表周報

訂制網站5個頻道的流量報表周報,通過XlsxWriter子產品将流量資料寫入Excel文檔,同時自動計算各頻道周平均流量,再生成資料報表。

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

40

41

42

43

44

45

46

47

48

49

50

51

52

53

54

55

56

57

58

59

60

61

62

63

64

65

66

67

68

69

70

71

72

73

74

75

76

77

<code>#!/usr/local/python27/bin/python2.7</code>

<code>#coding: utf-8</code>

<code>import</code> <code>sys</code>

<code>reload</code><code>(sys)</code>

<code>sys.setdefaultencoding(</code><code>'utf-8'</code><code>) </code><code>#用于解決windows轉linux出現的編碼問題</code>

<code>import</code> <code>xlsxwriter</code>

<code>workbook </code><code>=</code> <code>xlsxwriter.Workbook(</code><code>'chart.xlsx'</code><code>)</code>

<code>worksheet </code><code>=</code> <code>workbook.add_worksheet()</code>

<code>#建立圖表對象,定義圖表類型。</code>

<code>chart </code><code>=</code> <code>workbook.add_chart({</code><code>'type'</code><code>:</code><code>'column'</code><code>})</code>

<code>title </code><code>=</code> <code>[</code><code>'業務名稱'</code><code>,</code><code>'星期一'</code><code>,</code><code>'星期二'</code><code>,</code><code>'星期三'</code><code>,</code><code>'星期四'</code><code>,</code><code>'星期五'</code><code>,</code><code>'星期六'</code><code>,</code><code>'星期日'</code><code>,</code><code>'平均流量'</code><code>]</code>

<code>buname </code><code>=</code> <code>[</code><code>'業務官網'</code><code>,</code><code>'新聞中心'</code><code>,</code><code>'購物頻道'</code><code>,</code><code>'體育頻道'</code><code>,</code><code>'親子頻道'</code><code>]</code>

<code>data </code><code>=</code> <code>[</code>

<code>    </code><code>[</code><code>150</code><code>,</code><code>152</code><code>,</code><code>158</code><code>,</code><code>149</code><code>,</code><code>155</code><code>,</code><code>145</code><code>,</code><code>148</code><code>],</code>

<code>    </code><code>[</code><code>89</code><code>,</code><code>88</code><code>,</code><code>95</code><code>,</code><code>93</code><code>,</code><code>98</code><code>,</code><code>100</code><code>,</code><code>99</code><code>],</code>

<code>    </code><code>[</code><code>201</code><code>,</code><code>200</code><code>,</code><code>198</code><code>,</code><code>175</code><code>,</code><code>170</code><code>,</code><code>198</code><code>,</code><code>195</code><code>],</code>

<code>    </code><code>[</code><code>75</code><code>,</code><code>77</code><code>,</code><code>78</code><code>,</code><code>78</code><code>,</code><code>74</code><code>,</code><code>70</code><code>,</code><code>79</code><code>],</code>

<code>    </code><code>[</code><code>88</code><code>,</code><code>85</code><code>,</code><code>87</code><code>,</code><code>90</code><code>,</code><code>93</code><code>,</code><code>88</code><code>,</code><code>84</code><code>],</code>

<code>]</code>

<code>format</code> <code>=</code> <code>workbook.add_format() </code><code>#定義格式,用于在部分單元格調用</code>

<code>format</code><code>.set_border(</code><code>1</code><code>)</code>

<code>format_title </code><code>=</code> <code>workbook.add_format()</code>

<code>format_title.set_border(</code><code>1</code><code>)</code>

<code>format_title.set_bg_color(</code><code>'#cccccc'</code><code>)</code>

<code>format_ave </code><code>=</code> <code>workbook.add_format()</code>

<code>format_ave.set_border(</code><code>1</code><code>)</code>

<code>format_ave.set_num_format(</code><code>'0.00'</code><code>)</code>

<code>#使用行寫入第一行業務名稱及标題</code>

<code>worksheet.write_row(</code><code>'A1'</code><code>,title,format_title)</code>

<code>#使用列寫入從第一列的第二行開始寫入頻道标題</code>

<code>worksheet.write_column(</code><code>'A2'</code><code>,buname,</code><code>format</code><code>)</code>

<code>#從B2開始寫入資料項</code>

<code>worksheet.write_row(</code><code>'B2'</code><code>,data[</code><code>0</code><code>],</code><code>format</code><code>)</code>

<code>worksheet.write_row(</code><code>'B3'</code><code>,data[</code><code>1</code><code>],</code><code>format</code><code>)</code>

<code>worksheet.write_row(</code><code>'B4'</code><code>,data[</code><code>2</code><code>],</code><code>format</code><code>)</code>

<code>worksheet.write_row(</code><code>'B5'</code><code>,data[</code><code>3</code><code>],</code><code>format</code><code>)</code>

<code>worksheet.write_row(</code><code>'B6'</code><code>,data[</code><code>4</code><code>],</code><code>format</code><code>)</code>

<code>#定義圖表資料系列函數</code>

<code>def</code> <code>chart_series(cur_row):</code>

<code>#這裡是在求周平均值,I目前行的資料 = B:H目前行的值相加再求平均</code>

<code>    </code><code>worksheet.write_formula(</code><code>'I'</code><code>+</code><code>cur_row, </code><code>'= AVERAGE(B'</code><code>+</code><code>cur_row</code><code>+</code><code>':H'</code><code>+</code><code>cur_row</code><code>+</code><code>')'</code><code>,format_ave)</code>

<code>    </code><code>chart.add_series({</code>

<code>#這裡是在工作表Sheet1中指定該圖表類别的标簽範圍,從B1到H1,就是取了周一到周日。</code>

<code>        </code><code>'categories'</code><code>: </code><code>'=Sheet1!$B$1:$H$1'</code><code>,</code>

<code>#這裡是設定圖表資料的範圍,從B目前資料行到H目前資料行。      </code>

<code>        </code><code>'values'</code><code>: </code><code>'=Sheet1!$B$'</code><code>+</code><code>cur_row</code><code>+</code><code>':$H$'</code><code>+</code><code>cur_row,</code>

<code>        </code><code>'line'</code> <code>: {</code><code>'color'</code><code>:</code><code>'black'</code><code>},</code>

<code>#引用了業務名稱為圖列項       </code>

<code>        </code><code>'name'</code> <code>: </code><code>'=Sheet1!$A$'</code><code>+</code><code>cur_row,</code>

<code>        </code><code>})</code>

<code>for</code> <code>row </code><code>in</code> <code>range</code><code>(</code><code>2</code><code>,</code><code>7</code><code>):</code>

<code>    </code><code>chart_series(</code><code>str</code><code>(row))</code>

<code>#定義圖表樣式,每一個值都是一個不一樣的樣式。</code>

<code>chart.set_style(</code><code>2</code><code>)</code>

<code>#定義圖表的大小</code>

<code>chart.set_size({</code><code>'width'</code><code>:</code><code>577</code><code>,</code><code>'height'</code><code>:</code><code>287</code><code>})</code>

<code>#設定圖表上方的大标題</code>

<code>chart.set_title({</code><code>'name'</code><code>:</code><code>'業務流量周報圖'</code><code>})</code>

<code>#設定圖表y軸的小标題</code>

<code>chart.set_y_axis({</code><code>'name'</code><code>:</code><code>'Mb/s'</code><code>})</code>

<code>#插入圖表到A8的位置</code>

<code>worksheet.insert_chart(</code><code>'A8'</code><code>,chart)</code>

<code>workbook.close()</code>

二、實作TCP探測目标伺服器路由軌迹

scapy子產品需要tcpdump支援,生成報表需要graphviz,ImageMagick 圖像處理包支援。

yum install tcpdump graphviz ImageMagick -y

安裝scapy子產品

pip2.7 install scapy

<code> </code> 

<code>import</code> <code>os,sys,time,subprocess</code>

<code>import</code> <code>warnings,logging</code>

<code>#屏蔽無用的告警資訊 </code>

<code>warnings.filterwarnings(</code><code>"ignore"</code><code>,category</code><code>=</code><code>DeprecationWarning)</code>

<code>#屏蔽子產品IPV6多餘告警</code>

<code>logging.getLogger(</code><code>"scapy.runtime"</code><code>).setLevel(logging.ERROR)</code>

<code>from</code> <code>scapy.</code><code>all</code> <code>import</code> <code>traceroute</code>

<code>domains </code><code>=</code> <code>raw_input</code><code>(</code><code>" Please input one or more IP/domain: "</code><code>)</code>

<code>#切片空格,這裡就相當于把domains的内容,放到target清單中,可以通過target[number]調用;</code>

<code>target </code><code>=</code> <code>domains.split(</code><code>' '</code><code>)</code>

<code>dport </code><code>=</code> <code>[</code><code>80</code><code>]</code>

<code>if</code> <code>len</code><code>(target) &gt;</code><code>=</code> <code>1</code> <code>and</code> <code>target[</code><code>0</code><code>] !</code><code>=</code><code>'':</code>

<code>#啟動路由跟蹤</code>

<code>        </code><code>res,unans </code><code>=</code> <code>traceroute(target,dport</code><code>=</code><code>dport,retry</code><code>=</code><code>-</code><code>2</code><code>)</code>

<code>#res儲存的是路由跟蹤抓的封包資料,通過res.graph方法生成.svg檔案;        </code>

<code>        </code><code>res.graph(target</code><code>=</code><code>"&gt; test.svg"</code><code>)</code>

<code>        </code><code>time.sleep(</code><code>1</code><code>)</code>

<code>#調用shell指令,将svg轉成png,svg檔案可以在浏覽器中打開;        </code>

<code>        </code><code>subprocess.Popen(</code><code>"/usr/bin/convert test.svg test.png"</code><code>,shell</code><code>=</code><code>True</code><code>)</code>

<code>else</code><code>:</code>

<code>    </code><code>print</code> <code>"IP/domain Number of errors,exit"</code>

<a href="http://s3.51cto.com/wyfs02/M01/73/6D/wKiom1X9WErD2qv1AAH9xMmStUo554.jpg" target="_blank"></a>

本文轉自qw87112 51CTO部落格,原文連結:http://blog.51cto.com/tchuairen/1696374