zoukankan      html  css  js  c++  java
  • Python 调用阿里云 API 收集 ECS 数据

    #!/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, sys
    
    try:
        from termcolor import colored
        from xlsxwriter import workbook
        from aliyunsdkcore import client
        from aliyunsdkecs.request.v20140526 import DescribeInstancesRequest
    except 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 result
    
    def 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()
  • 相关阅读:
    洛谷P1434 滑雪
    P1855 榨取kkksc03
    C#中将表示颜色的string转换成Color
    DevExpress的对话框XtraMessageBox的使用
    Winform中怎样根据Name获取同窗体的控件
    Winform中使用代码编写Button按钮的点击事件
    SqlServer 2014还原数据库时提示:无法在已有的""上还原文件,请重新发出RESTORE语句,用WITH REPLACE来覆盖原先存在的文件
    SqlServer 2014 还原数据库时提示:操作系统返回了错误5,,拒绝访问
    Windows 7 上怎样打开SQL Server 配置管理器
    SqlServer2014怎样还原数据库
  • 原文地址:https://www.cnblogs.com/wangxiaoqiangs/p/5369336.html
Copyright © 2011-2022 走看看