Python 批量操作设备的实现步骤

目录
  • 背景需求
    • - 方案一
    • - 方案二
    • 方案三
  • 准备工作
  • 动手操作
  • 总结

全民编程的时代,怎么能少了测试同学的身影。最近在学习Python,刚好活学活用,来实战一波

背景需求

某天午休未睡醒的我,突然接到一个Leader在群里@小盆,把平台上100台设备硬盘都上传一套多媒体文件,线上任务需要进行测试。

- 方案一

如果本人勤快且工作任务不多的话,可能就哼哧哼哧,一台一台设备操作着

  • 远程登陆设备
  • 从本地把文件拷贝到设备中
  • 重复前面两个步骤

不行阿,我这边手上还有其他任务呢,交付日期也是今天,这样做太浪费时间了吧,方案一被否决
按照传统的步骤,重复且低效,哪我去找开发去把相应的接口要过来吧

- 方案二

  • 找到相关设备上传文件的接口
  • 把文件上传到服务器,生成下载链接
  • 使用Postman的工具去请求
  • 重复第三步,更改设备IP请求

试了一两次,这也太繁琐了吧,每请求一台设备,就要更改下一台的设备IP,整个过程也没有节省多少时间阿。
内心困惑之时,我这不正在学习了Python,让Python来帮我做事吧,节省下的时间好好放松一下(^-^)V,想到的方案三

方案三

  • 找到了相关设备功能接口
  • 找研发拿到100台设备详情(设备都是同样型号)
  • Python写脚本
  • 运行,休息

好呐,这还差不多,话不多说,行动吧

准备工作

我们需要准备的环境

IDE:Pycharm
version: Python3.7

Python相关的库

  • http库(request)下载:pip install request
  • josn下载:用于解析URL相关的内容

前提:

分析接口请求方式、请求参数、body和返回信息(示例)

上传文件接口:  /api/Manager/dev/filetousb
请求方式: POST
请求参数:Content-Type = application/json

  Body : {
              "action":"start",
              "file:[
              {
              "fileurl":"http://10.22.26.21/sw_bin/media/JueJing.jpg",
               "filename":"JueJing.jpg",
               "directory":"",
               "filemd5":"12345678910999"
              }
              ]
          }

关注到多媒体相关的文件都是以链接形式的,因此先提前把文件都上传到服务器,生成了文件链接和文件的MD5值

使用Python request库模拟网络请求给设备端

Body内容是JOSN的格式,因此需要使用Python内置的josn库

100台设备都是不同IP,所以提前找到设备IP列表相信息,放到text文件里,则需要使用Python文件管理去一行一行去读取放到列表里,这样方便传值进行请求

动手操作

经过上面的准备和分析,期间还去查了资料,(太菜了,盲人摸河一步一步的做)

三下五除二,一番实现调试,写下初级小白的脚本(大佬们帮忙看看,指教指教)

import requests
import json

#使用的接口
usbfile = "/api/Manager/dev/filetousb"
#body内容,需要上传的文件
mediafile = {
                "action":"start",
                "file:[
                {
                "fileurl":"http://10.22.26.21/sw_bin/media/JueJing.jpg",
                 "filename":"JueJing.jpg",
                 "directory":"",
                 "filemd5":"12345678910999"
                }
                ]
            }   

#定义空的deviceiplist,用来添加测试设备的IP

deviceiplist = []

# 接口请求实现方法

def  do_post(ip,api,data):

    headers = {"Content-Type": "application/json"}

    url = "http://"+ip+ ":8080" + api

    print (url)

    try:
        r = requests.post(url,headers = headers,data = json.dumps(data),timeout= 10)
        print(r.status_code)
        print(r.content.decode("utf-8"))

    except requests.exceptions.ConnectionError:

        requests.status_code = "Connection refused"

#读取设备IP文件,并添加到列表里

with open( "deviceip.txt","r") as f:
    while True:
        line = f.readline()
        if not line:
            break
        else:
            ip = [i for i in line]
            deviceiplist.append(ip)

f.close()

# 执行循环请求100次
for i in range(100):

    print(iplist[i])

    time.sleep(10)
    # 上传多媒体文件
    # do_post(deviceiplist[i],usbfile,mediafile)

运行过程,我们就拿着省下来的时间来,搞其他事情,争取早点下班(笑哭.jpg)
本次时间,比较紧急,脚本写的也比较简单,如果有更好的技能,欢迎大家多多留言,让我这个小白增加眼界。

总结

到此这篇关于Python 批量操作设备的实现步骤的文章就介绍到这了,更多相关Python 批量操作设备内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

(0)

相关推荐

  • Python操作Word批量生成合同的实现示例

    背景:大约有3K家商家需要重新确认信息并签订合同.合同是统一的Word版本.每个供应商需要修改合同内的金额部分.人工处理方式需要每个复制粘贴且金额要生成大写金额.基于重复工作可偷懒.用Python解救一下. #导入对应数据库 import numpy as np import pandas as pd import os import docx from docx.shared import Pt from docx.oxml.ns import qn #修改项目文件地址 os.chdir(r'

  • python批量创建变量并赋值操作

    一,简单的情况: 核心是exec函数,exec函数可以执行我们输入的代码字符串.exec函数的简单例子: exec ('print "hello world"') hello world 可以很清晰的看到,我们给exec传入一个字符串'print "hello world"',exec是执行字符串里面的代码print "hello world".根据这个特性,我们可以用占位符实现我们对变量的定义,如: exec ("temp%s=1&q

  • python文件操作之批量修改文件后缀名的方法

    1.引言 需要把.dat 格式 转化成 .txt格式 2.实现 ##python批量更换后缀名 import os # 列出当前目录下所有的文件 files = os.listdir('.') #print('files',files) for filename in files: portion = os.path.splitext(filename) # 如果后缀是.dat if portion[1] == ".dat": # 重新组合文件名和后缀名 newname = porti

  • python UDF 实现对csv批量md5加密操作

    工作上遇到需求,一批手机号要md5加密导出.为了保证数据安全,所以没有采用网上工具来加密. md5的加密算法是开源的且成熟的,很多语言都有对应包可以直接用,我写了一个简单的python来实现,另一位同事做了一个hiveUDF来实现,这里都给大家分享一下. 目标: 读取csv文件,并且对其中的内容进行md5加密,32位加密,将加密后的密文存入另一个csv文件. python实现: (1)准备好要读取的csv文件.单列,一行存一个手机号码. (2)python代码: #encoding=utf8 i

  • 使用Python实现批量ping操作方法

    在日常的工作中,我们通常会有去探测目标主机是否存活的应用场景,单个的服务器主机可以通过计算机自带的DOS命令来执行,但是业务的存在往往不是单个存在的,通常都是需要去探测C段的主机(同一个网段下的存活主机),这样使用DOS来进行操作是不可取,探测的速度太慢了,不满足实际需要.一般批量的操作需要使用脚本进行一键部署执行,本文主要通过使用Python语言来实现批量ping的操作(使用多线程实现Python批量处理) Python版本 :Python3 使用的第三方库:subprocess, loggi

  • Python脚本操作Excel实现批量替换功能

    大家好,给大家分享下如何使用Python脚本操作Excel实现批量替换. 使用的工具 Openpyxl,一个处理excel的python库,处理excel,其实针对的就是WorkBook,Sheet,Cell这三个最根本的元素~ 明确需求原始excel如下 我们的目标是把下面excel工作表的sheet1表页A列的内容"替换我吧"批量替换为B列的"我用来替换的x号选手" 实现替换后的效果图,C列为B列替换A列的指定内容后的结果 实现以上功能的同时,我也实现excel

  • python批量赋值操作实例

    变量名和变量值俊发生规律的变化,利用for循环完成赋值操作. 举个例子: for i in range(1, 10): exec("t%d=i"%i) print(t1) print(t2) print(t3) print(t4) print(t5) print(t6) print(t7) print(t8) print(t9) 执行结果: 1 2 3 4 5 6 7 8 9 利用python中的exec()函数来完成. 以上这篇python批量赋值操作实例就是小编分享给大家的全部内容

  • Python 批量操作设备的实现步骤

    目录 背景需求 - 方案一 - 方案二 方案三 准备工作 动手操作 总结 全民编程的时代,怎么能少了测试同学的身影.最近在学习Python,刚好活学活用,来实战一波 背景需求 某天午休未睡醒的我,突然接到一个Leader在群里@小盆,把平台上100台设备硬盘都上传一套多媒体文件,线上任务需要进行测试. - 方案一 如果本人勤快且工作任务不多的话,可能就哼哧哼哧,一台一台设备操作着 远程登陆设备 从本地把文件拷贝到设备中 重复前面两个步骤 不行阿,我这边手上还有其他任务呢,交付日期也是今天,这样做

  • Python批量获取基金数据的方法步骤

    20年初准备投资基金,想爬取基金的业绩数据. 20年基金迎来了爆发式增长,现把代码开源以供参考. 本代码只能实现初步汇总,输出csv文件来保存基金的单位&累计净值,后期仍需要结合统计方法来筛选优质基金. 参考了网上的部分代码,实在不记得出处了,侵删. import requests import time import execjs start = time.perf_counter() # 获取所有基金编号 def getAllCode(): url = 'http://fund.eastmo

  • 使用Python批量压缩tif文件操作步骤

    1.前言 我在进行DEM数据的裁剪时,发现各个省的数据量非常大,比如说四川省的30m的DEM数据的大小为2G.考虑到有限的电脑磁盘空间,我对Tif文件采用了LZW压缩. 2.流程 3.批量压缩代码 #文件夹中每个文件都进行压缩 # -*- coding: utf-8 -*- import rasterio as rio import rasterio import os from tqdm import tqdm #每个线程选择一个文件夹 Input_path ="输入文件夹"+&qu

  • python批量压缩图像的完整步骤

    目录 背景 解决方案 操作步骤 要求 步骤 附:批量将图片的大小设置为指定大小 写在后面 背景 今天在工作中,同事遇到一个上传图片的问题:系统要求的图片大小不能超过512KB.但是同事又有很多照片.这要是每一个照片都用ps压缩的话,那岂不是很崩溃.于是我写了一个脚本,可以批量压缩图片到指定大小.直接造福同事.提高同事的工作效率. 解决方案 其实也不用卖关子了,就是使用python的pillow包就可以对图片进行压缩,如果一个图片已经压缩到指定大小了,那就停止压缩,如果没有达到指定大小,那就对压缩

  • Python批量对word文档进行操作步骤

    目录 导读 应用 细节介绍 导读 前面几章我们以经介绍了怎么批量对excel和ppt操作今天我们说说对word文档的批量操作 应用 python-docx允许您创建新文档以及对现有文档进行更改.实际上,它只允许您对现有文档进行更改:只是如果您从一个没有任何内容的文档开始,一开始可能会觉得您是从头开始创建一个文档. 这个特性是一个强大的特性.文档的外观很大程度上取决于删除所有内容时留下的部分.样式.页眉和页脚等内容与主要内容分开包含,允许您在起始文档中进行大量自定义,然后出现在您生成的文档中. 让

  • python实现自动化群控的步骤

    1. 前言 群控,相信大部分人都不会陌生!印象里是一台电脑控制多台设备完成一系列的操作,更多的人喜欢把它和 Hui 产绑定在一起! 事实上,群控在自动化测试中也被广泛使用!接下来的几篇文章,我将带大家聊聊企业级自动化中,群控正确的使用姿势! 本篇先从基础篇开始,聊聊使用「 Python + adb 」命令如何编写一套群控脚本 2. 准备 在本机安装 Android 开发环境,保证 adb 被添加到环境变量 将准备好的多台设备,使用数据线( 或者通过 Hub )连接到电脑上 通过 adb devi

  • Python批量图片去水印的方法

    ​平常工作中,有时为了采用网络的一些素材,但这些素材往往被打了水印,如果我们不懂PS就无法去掉水印,或者无法批量去掉水印.这些就很影响我们的工作效率. 今天我们就一起来,用Python + OpenCV三步去除水印,去水印需要使用的库:cv2.numpy.cv2是基于OpenCV的图像处理库,可以对图像进行腐蚀,膨胀等操作:numpy这是一个强大的处理矩阵和维度运算的库. 图片去水印原理 1.标定噪声的特征,使用cv2.inRange二值化标识噪声对图片进行二值化处理,具体代码:cv2.inRa

  • 如何利用Python批量处理行、列和单元格详解

    目录 精确调整工作表的行高和列宽 批量更改多个工作簿的数据格式 批量更改工作簿的外观格式 设置字体格式 修改字体为宋体 修改字号 字体加粗 字体颜色 单元格填充颜色 对齐方式 添加合适粗细的边框 替换工作簿的行数据 提取指定数据 提取列数据 追加行数据 提取所有工作表的唯一值 总结 精确调整工作表的行高和列宽 步骤 打开工作簿. 遍历所有工作表 核心代码 for i in workbook.sheets: value = i.range('A1').expand('table') value.c

  • Python批量处理工作簿和工作表的实现示例

    目录 批量新建并保存工作簿 批量打开一个文件夹中的打开工作簿 批量重命名一个工作簿的所有工作表 批量重命名多个工作簿 批量重命名多个工作簿中的同名工作表 将一个工作簿的所有工作表批量复制到其他工作簿 按条件将一个工作表拆分为多个工作簿 批量新建并保存工作簿 代码 import xlwings as xw # 启动 Excel,但不新建工作簿 app = xw.App(visible=True,add_book=False) for i in range(5): #新建工作簿 workbook =

  • python批量处理打开多个文件

    背景: 有时候我们需要在服务器上同时运行多个程式,但是却需要一个一个的打开,比较费时间,而且一旦服务器重启后,不懂程式运行的人受限于环境及代码原理,很难逐个将程式逐个打开并运行,可以利用python的批处理功能将多个程式写在一个批处理文件中来完成这项工作,下次只需要双击运行批处理文件就可以了,省事省劲,如果你技术可以,甚至可以将这些写成winodws的服务,这样会更省事. 批处理测试: 首先写一个最简答的批处理文件. 在txt中写入如下代码: start cmd /k "echo helloWo

随机推荐