博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Python 调用阿里云 API 收集 ECS 数据
阅读量:6630 次
发布时间:2019-06-25

本文共 3288 字,大约阅读时间需要 10 分钟。

#!/usr/bin/env python# coding: utf-8# author: Wang XiaoQiang'''功能介绍:1、调用阿里云API,收集所有区域 ECS 信息2、将需要的数据整理、生成 Excel 文档3、关于阿里 sdk 的安装,api 的调用请参考阿里云官网4、xlsxwriter 请参考这里:http://xlsxwriter.readthedocs.org/'''import json, systry:    from termcolor import colored    from xlsxwriter import workbook    from aliyunsdkcore import client    from aliyunsdkecs.request.v20140526 import DescribeInstancesRequestexcept ImportError as e:    print(colored('%s : %s' % ('Error', e), 'red'))    exit(9)reload(sys)sys.setdefaultencoding('utf8')def get_sys_info(key, secret, zone):    '''    1、获取该区域全部主机详细信息    2、参数:cn-qingdao、cn-hangzhou、cn-beijing 等    '''    # 与阿里云建立有效连接    clt = client.AcsClient(key, secret, zone)    # 获取该区域全部实例详细信息    request = DescribeInstancesRequest.DescribeInstancesRequest()    # 将数据格式化成 json,默认为 XML    request.set_accept_format('json')    # 发起请求,获取数据    result = json.loads(clt.do_action(request)).get('Instances').get('Instance')    return result    def format_data(data_info):    '''    从全部数据中整理出需要的数据    '''    result = []    for line in data_info:        data = (            line.get('InstanceId'),            line.get('ZoneId'),            line.get('HostName'),            line.get('InstanceName'),            line.get('PublicIpAddress').get('IpAddress')[0],            line.get('InnerIpAddress').get('IpAddress')[0],            line.get('Cpu'),            line.get('Memory'),            line.get('InternetMaxBandwidthOut'),            line.get('Status'),            line.get('CreationTime'),            line.get('ExpiredTime')        )        result.append(data)    return resultdef write_excel(file, data):    '''    1、设置 Excel 样式    2、将数据写入到 Excel 中    '''    # 生成 Excel 文件    work = workbook.Workbook(file)    # 建立工作表,表名默认    worksheet = work.add_worksheet()    # 设置字体加粗、字体大小    format_title = work.add_format({
'bold': True, 'font_size': 16}) # 设置水平对齐、垂直对齐 format_title.set_align('center') format_title.set_align('vcenter') format_body = work.add_format({
'font_size': 14}) # 设置样式,行高、列宽 worksheet.set_row(0, 25) worksheet.set_column(0, 0, 30) worksheet.set_column(1, 1, 20) worksheet.set_column(2, 3, 28) worksheet.set_column(4, 5, 25) worksheet.set_column(6, 6, 12) worksheet.set_column(7, 9, 16) worksheet.set_column(10, 11, 25) # 定义表头 title = ( '实例 ID', '所在区域', '主机名称', '主机别名', '公网地址', '私网地址', 'CPU 核数', '内存大小 MB', '网络带宽 MB', '运行状态', '创建时间', '过期时间' ) row = 0 col = 0 # 表头写入文件,引用样式 for item in title: worksheet.write(row, col, item, format_title) col+=1 # 内容写入文件,引用样式 for line in data: row+=1 col = 0 for key in line: worksheet.write(row, col, key, format_body) col+=1 work.close()def main(): key = 'Access Key Id' secret = 'Access Key Secret' zones = ['cn-beijing', 'cn-shanghai', 'cn-qingdao', 'cn-hangzhou'] filename = './aliyunSystemToExcel.xlsx' result = [] for zone in zones: info = get_sys_info(key, secret, zone) data = format_data(info) [ result.append(line) for line in data ] write_excel(filename, result)if __name__ == '__main__': main()

转载于:https://www.cnblogs.com/wangxiaoqiangs/p/5369336.html

你可能感兴趣的文章
SSM整合,个人总结和step
查看>>
嵌入式Linux ARM汇编(三)——ARM汇编指令(四)
查看>>
嵌入式 Linux 系统移植——BSP分析
查看>>
Linux-基础命令测试(一)
查看>>
利用 onload 事件监控跨站资源
查看>>
Linux 阶段练习(2)
查看>>
原创黑页
查看>>
我的友情链接
查看>>
短信发送状态报告(Status Report)的处理
查看>>
oracle第一章
查看>>
在一台Mac上不同平台同时使用多个Git账号
查看>>
leetcode-868-Binary Gap
查看>>
总结Android规范(参考阿里规范, 仅用于公司内部)
查看>>
How to extend size of LVM
查看>>
黑马程序员---java基础------------------String类
查看>>
什么是Date对象一个内置对象Date:
查看>>
Activity.this和getApplicationContext()的差异
查看>>
用“倍增法”求最近公共祖先(LCA)
查看>>
何不食肉糜 | 机器学习自学指南
查看>>
jq 点击按钮换图运动
查看>>