async def test_param(self): users = await respool.first_user() await self._test_api( api_=User().api_BatchSetDesktopManager, users__1=ParamSchema( valid_values=[users[0].end_user_id], invalid_values=[None], error_codes=['MissingUsers'] ), is_desktop_manager=ParamSchema( valid_values=[0, 1, None], invalid_values=['invalid@无效'], error_codes=['ServiceUnavailable'] ) )

时间: 2024-02-15 14:27:52 浏览: 136
这段代码看起来是一个异步函数,其中调用了一个名为respool的对象的first_user()方法获取用户信息,然后调用了一个名为_test_api()的方法,传入了三个参数:api_表示要测试的API接口,users__1表示一个名为ParamSchema的参数模式,包含了valid_values、invalid_values和error_codes等信息,is_desktop_manager也是ParamSchema类型的参数模式,包含了相应的有效和无效值以及错误代码。这段代码可能是用于进行API接口测试的。
相关问题

async def test_param(self): desktop = await respool.first_desktop(desktop_status=DesktopStatus.RUNNING, charge_type='PrePaid') async with desktop: await self._test_api( api_=Desktop().api_DescribeRefundPrice, refund_type=ParamSchema( valid_values=[None, 'RemainRefund'], invalid_values=['invalid@无效'], error_codes=['InvalidRefundType.ValueNotSupported'] ), refund_param_map=ParamSchema( valid_values=[None, '{ "IsChargeTypeConvertOrder":"true","refundNotRelease":"true","refundNotFinishPurchase":"true" }'], invalid_values=['invalid@无效'], error_codes=['InvalidRefundPriceParamType.ValueNotSupported'] ), desktop_id__1=ParamSchema( valid_values=[desktop.desktop_id], invalid_values=[None, 'invalid@无效'], error_codes=['MissingDesktopId', 'InvalidDesktopId.ValueNotSupported'] ) )

这段代码是一个方法,用于测试Desktop类的api_DescribeRefundPrice方法的参数。其中,首先通过respool.first_desktop方法获取一个运行中且计费方式为PrePaid的桌面对象,然后使用async with语句将桌面锁定,避免其他协程同时对其进行操作。接着,使用_test_api方法对api_DescribeRefundPrice的三个参数进行测试:refund_type,refund_param_map和desktop_id__1。其中,ParamSchema定义了每个参数的有效值、无效值和对应的错误代码,目的是验证api_DescribeRefundPrice方法对参数的处理是否符合预期。

import uvicorn from fastapi import FastAPI, UploadFile, File from io import BytesIO from PIL import Image, ImageDraw from utils.operation import YOLO def detect(onnx_path='ReqFile/yolov5n-7-k5.onnx', img=r'ReqFile/bus.jpg', show=True): ''' 检测目标,返回目标所在坐标如: {'crop': [57, 390, 207, 882], 'classes': 'person'},...] :param onnx_path:onnx模型路径 :param img:检测用的图片 :param show:是否展示 :return: ''' yolo = YOLO(onnx_path=onnx_path) # 加载yolo类 det_obj = yolo.decect(img) # 检测 # 打印检测结果 print(det_obj) # 画框框 if show: img = Image.open(img) draw = ImageDraw.Draw(img) for i in range(len(det_obj)): draw.rectangle(det_obj[i]['crop'], width=3) img.show() # 展示 return det_obj app = FastAPI() @app.get("/") def read_root(): return {"Hello": "World"} @app.post("/detect/") async def create_upload_file(file: UploadFile = File(...)): contents = await file.read() # 接收浏览器上传的图片 im1 = BytesIO(contents) # 将数据流转换成二进制文件存在内存中 # 返回结果 return detect(onnx_path='ReqFile/best-0206.onnx', img=im1, show=False) # 启动项目 if __name__ == "__main__": uvicorn.run(app='main:app', port=8000, host='0.0.0.0', reload=True)

这是一个使用 FastAPI 和 YOLO 模型进行目标检测的 Python 代码。其中 `detect()` 函数接收一个 ONNX 模型路径和图片,使用 YOLO 模型进行目标检测,并返回检测结果。`create_upload_file()` 函数用于接收浏览器上传的图片,调用 `detect()` 函数进行目标检测,并返回检测结果。最后使用 Uvicorn 启动项目。
阅读全文

相关推荐

async searchNewsSemi(dto: SearchDto) { dto.page = dto.page ? dto.page * 1 : 1; dto.limit = dto.limit ? dto.limit * 1 : 10; const queryParam = { query: { bool: { must: [], filter: [], }, }, aggs: {}, size: dto.limit, from: (dto.page - 1) * dto.limit, track_total_hits: true, }; if (dto.keyword) { const k = dto.keyword.split('_'); queryParam.query.bool.must.push({ match: { [k[0]]: k[1], }, }); } else { queryParam.query.bool.must.push({ match_all: {}, }); } if (dto.category) { if (Array.isArray(dto.category)) { dto.category.forEach((c) => { queryParam.aggs[${c}Terms] = { terms: { field: ${c}, }, }; }); } else { // @ts-ignore queryParam.aggs[${dto.category}Terms] = { terms: { field: ${dto.category}, }, }; } } if (dto.endTime) { let startTime = dto.startTime; if (!startTime) { const endTimeNew = new Date(dto.endTime); const startTimeStamp = endTimeNew.setDate(endTimeNew.getDate() - 7); startTime = dateUtil.pattern( new Date(startTimeStamp), 'yyyy-MM-ddTHH:mm:ssZ', ); } // 时间范围 queryParam.query.bool.filter.push({ range: { insert_time: { gte: startTime, lte: dto.endTime, }, }, }); // 时间范围分组 queryParam.aggs['insertTimeTerms'] = { date_histogram: { field: 'insert_time', interval: 'day', format: 'yyyy-MM-dd hh:MM:ss', }, }; } console.log('param:' + JSON.stringify(queryParam)); const result = await this.elasticSearchService.search({ index: 'news_semi', body: queryParam, }); const resultBody = result['body']; const resultData = resultBody['hits']['hits']; const aggregations = resultBody['aggregations']; const rest = { total: resultBody['hits']['total']['value'], data: resultData.map((item) => { const obj = { ...item }; if (obj.highlight) { obj['_source']['content'] = obj['highlight']['content'][0]; // 删除高亮字段 delete obj.highlight; } return obj; }), category: {}, }; if (aggregations) { for (const agg in aggregations) { rest.category[agg] = aggregations[agg]['buckets']; } } return aggregations; }

const jenkinsApi1 = axios.create({ baseURL: '/view', // Jenkins的地址 headers: { method: "GET", 'Content-Type': 'application/json' }, }); const jenkinsApi2 = axios.create({ baseURL: '/view', headers: { method: "POST", 'Content-Type': 'application/json', Authorization: Basic ${btoa('jiancheng5.huang:11fa4770b79980ba20eecaa288fa15ce34')} }, }); export default { getJobInfo(jobName: string) { return jenkinsApi1.get(/view/yanting1.lin/job/${jobName}/2/api/json?pretty=true&tree=url,displayName,actions[parameters[name,value]],previousBuild[url]); }, getJobInfo1() { return jenkinsApi1.get(/view/yanting1.lin/job/build_test/api/json?pretty=true&tree=property[parameterDefinitions[defaultParameterValue[name,value]]]); }, buildWithParameters(jobName: string, parameters: any) { return jenkinsApi2.post(/view/yanting1.lin/job/${jobName}/buildWithParameters, parameters) } };const names2 = ref([]) const values2 = ref([]); const fetchJobInfo2 = async () => { try { const response = await jenkinsApi1.getJobInfo1(); const parameterDefinitions = response.data.property[5].parameterDefinitions const defaultParameterValue = parameterDefinitions.map(param => param.defaultParameterValue) names2.value = defaultParameterValue.map(param => param.name) values2.value = defaultParameterValue.map(param => param.value) console.log(defaultParameterValue); console.log(names2); } catch (error) { console.log(error); } }; const buildJob = async () => { const parameters = {}; names2.value.forEach((name, index) => { parameters[name] = values2.value[index]; console.log(JSON.stringify(parameters)) }); // try { // await jenkinsApi2.buildWithParameters('build_test', JSON.stringify(parameters)); // console.log('构建已启动'); // } catch (error) { // console.log(error); // } }; fetchJobInfo2(); <el-form label-width="120px"> <el-form-item v-for="(name, index) in names2" :key="index" :label="name"> <el-input v-model="values2[index]" /> </el-form-item> <el-button type="primary" @click="buildJob"> 确认 </el-button> </el-form>在这段代码中怎么实现将在el-input输入的参数传给Jenkins并根据这些参数启动构建

const CryptoJS = require('./crypto-js'); // 云函数入口文件 const cloud = require('wx-server-sdk') cloud.init({ env: cloud.DYNAMIC_CURRENT_ENV }) // 使用当前云环境 const db = cloud.database(); /** * 将字符串转化为数字(若字符串唯一,则结果也具有唯一性) * * @param {String} s 需要转换的字符串 * @param {Number} n 返回的结果的数字位数 */ async function convertToUniqueDigits(s, n) { // 使用哈希算法将字符串转换为数字 const m = sha256(s); // 将哈希值转换为数字,并将结果映射到指定的位数 let x = parseInt(m, 16) % (10n); // 如果结果中有重复的数字,增加一个偏移量 while (hasDuplicateDigits(x)) { x = (x + 1) % (10n); } //检查数据库是否存在这个id const hasUID = await checkHasUid(x); //存在这个id,则重新调用该函数并增加转化结果的位数 if(hasUID>0){ return convertToUniqueDigits(s,n+1); //发现不能使用++,会无限循环 } //不存在这个ID,直接返回结果 else{ return x; } } //检查是否存在相同的uid async function checkHasUid(uid){ const res = await db.collection('user_list').where({ uid: String(uid) }).count(); return res.total } function sha256(s) { // 使用 SHA-256 哈希算法将字符串转换为哈希值 const hash = CryptoJS.SHA256(s); return hash.toString(CryptoJS.enc.Hex); } function hasDuplicateDigits(x) { // 检查数字中是否有重复的数字 const digits = String(x).split(''); return digits.length !== new Set(digits).size; } module.exports = { convertToUniqueDigits: convertToUniqueDigits };

优化精简这段代码// pages/Stores/Stores.js // 请求封装 import request from '../../utils/request' // 高德地图 import amapFile from '../../libs/amap-wx.130' // 地图实例 var myAmapFun Page({ data: { map: [] }, onLoad(options) { console.log(options) const that = this wx.createWACode({ path: '/pages/index/index', width: 430, scene: 'custom_value' }).then(res => { // 在页面中显示生成的小程序码 this.setData({ qrcodeUrl: res.path }); }).catch(err => { console.error(err); }); myAmapFun = new amapFile.AMapWX({ key: '5409c5fd8a9d2c7dfecef1faa8cd3ffc' }); wx.getLocation({ type: 'wgs84', isHighAccuracy: true, success(res) { that.setData({ latitude: res.latitude, longitude: res.longitude, speed: res.speed, accuracy: res.accuracy }) request( '/stores/stores', {}, 'POST').then(res => { that.setData({ map: res.data, }) that.calculateDistance() }) } }) }, // 计算附近门店距离 calculateDistance() { const that = this; const mapVar = JSON.parse(JSON.stringify(that.data.map)); const promises = []; mapVar.forEach(item => { const origin = that.data.longitude + ',' + that.data.latitude; const destination = item.longitude + ',' + item.latitude; const promise = new Promise((resolve, reject) => { myAmapFun.getDrivingRoute({ origin: origin, destination: destination, success: function (data) { item.distance = Math.round(data.paths[0].distance / 100) / 10; resolve(); }, fail: function (err) { reject(err); } }); }); promises.push(promise); }); Promise.all(promises).then(() => { that.setData({ map: mapVar }); console.log(that.data.map) }).catch(err => { console.error(err); }); }, onShareAppMessage() { return { title: '分享标题', path: '/pages/index/index?custom_param=custom_value' }; } })

最新推荐

recommend-type

Angular程序高效加载与展示海量Excel数据技巧

资源摘要信息: "本文将讨论如何在Angular项目中加载和显示Excel海量数据,具体包括使用xlsx.js库读取Excel文件以及采用批量展示方法来处理大量数据。为了更好地理解本文内容,建议参阅关联介绍文章,以获取更多背景信息和详细步骤。" 知识点: 1. Angular框架: Angular是一个由谷歌开发和维护的开源前端框架,它使用TypeScript语言编写,适用于构建动态Web应用。在处理复杂单页面应用(SPA)时,Angular通过其依赖注入、组件和服务的概念提供了一种模块化的方式来组织代码。 2. Excel文件处理: 在Web应用中处理Excel文件通常需要借助第三方库来实现,比如本文提到的xlsx.js库。xlsx.js是一个纯JavaScript编写的库,能够读取和写入Excel文件(包括.xlsx和.xls格式),非常适合在前端应用中处理Excel数据。 3. xlsx.core.min.js: 这是xlsx.js库的一个缩小版本,主要用于生产环境。它包含了读取Excel文件核心功能,适合在对性能和文件大小有要求的项目中使用。通过使用这个库,开发者可以在客户端对Excel文件进行解析并以数据格式暴露给Angular应用。 4. 海量数据展示: 当处理成千上万条数据记录时,传统的方式可能会导致性能问题,比如页面卡顿或加载缓慢。因此,需要采用特定的技术来优化数据展示,例如虚拟滚动(virtual scrolling),分页(pagination)或懒加载(lazy loading)等。 5. 批量展示方法: 为了高效显示海量数据,本文提到的批量展示方法可能涉及将数据分组或分批次加载到视图中。这样可以减少一次性渲染的数据量,从而提升应用的响应速度和用户体验。在Angular中,可以利用指令(directives)和管道(pipes)来实现数据的分批处理和显示。 6. 关联介绍文章: 提供的文章链接为读者提供了更深入的理解和实操步骤。这可能是关于如何配置xlsx.js在Angular项目中使用、如何读取Excel文件中的数据、如何优化和展示这些数据的详细指南。读者应根据该文章所提供的知识和示例代码,来实现上述功能。 7. 文件名称列表: "excel"这一词汇表明,压缩包可能包含一些与Excel文件处理相关的文件或示例代码。这可能包括与xlsx.js集成的Angular组件代码、服务代码或者用于展示数据的模板代码。在实际开发过程中,开发者需要将这些文件或代码片段正确地集成到自己的Angular项目中。 总结而言,本文将指导开发者如何在Angular项目中集成xlsx.js来处理Excel文件的读取,以及如何优化显示大量数据的技术。通过阅读关联介绍文章和实际操作示例代码,开发者可以掌握从后端加载数据、通过xlsx.js解析数据以及在前端高效展示数据的技术要点。这对于开发涉及复杂数据交互的Web应用尤为重要,特别是在需要处理大量数据时。
recommend-type

管理建模和仿真的文件

管理Boualem Benatallah引用此版本:布阿利姆·贝纳塔拉。管理建模和仿真。约瑟夫-傅立叶大学-格勒诺布尔第一大学,1996年。法语。NNT:电话:00345357HAL ID:电话:00345357https://theses.hal.science/tel-003453572008年12月9日提交HAL是一个多学科的开放存取档案馆,用于存放和传播科学研究论文,无论它们是否被公开。论文可以来自法国或国外的教学和研究机构,也可以来自公共或私人研究中心。L’archive ouverte pluridisciplinaire
recommend-type

【SecureCRT高亮技巧】:20年经验技术大佬的个性化设置指南

![【SecureCRT高亮技巧】:20年经验技术大佬的个性化设置指南](https://www.vandyke.com/images/screenshots/securecrt/scrt_94_windows_session_configuration.png) 参考资源链接:[SecureCRT设置代码关键字高亮教程](https://wenku.csdn.net/doc/6412b5eabe7fbd1778d44db0?spm=1055.2635.3001.10343) # 1. SecureCRT简介与高亮功能概述 SecureCRT是一款广泛应用于IT行业的远程终端仿真程序,支持
recommend-type

如何设计一个基于FPGA的多功能数字钟,实现24小时计时、手动校时和定时闹钟功能?

设计一个基于FPGA的多功能数字钟涉及数字电路设计、时序控制和模块化编程。首先,你需要理解计时器、定时器和计数器的概念以及如何在FPGA平台上实现它们。《大连理工数字钟设计:模24计时器与闹钟功能》这份资料详细介绍了实验报告的撰写过程,包括设计思路和实现方法,对于理解如何构建数字钟的各个部分将有很大帮助。 参考资源链接:[大连理工数字钟设计:模24计时器与闹钟功能](https://wenku.csdn.net/doc/5y7s3r19rz?spm=1055.2569.3001.10343) 在硬件设计方面,你需要准备FPGA开发板、时钟信号源、数码管显示器、手动校时按钮以及定时闹钟按钮等
recommend-type

Argos客户端开发流程及Vue配置指南

资源摘要信息:"argos-client:客户端" 1. Vue项目基础操作 在"argos-client:客户端"项目中,首先需要进行项目设置,通过运行"yarn install"命令来安装项目所需的依赖。"yarn"是一个流行的JavaScript包管理工具,它能够管理项目的依赖关系,并将它们存储在"package.json"文件中。 2. 开发环境下的编译和热重装 在开发阶段,为了实时查看代码更改后的效果,可以使用"yarn serve"命令来编译项目并开启热重装功能。热重装(HMR, Hot Module Replacement)是指在应用运行时,替换、添加或删除模块,而无需完全重新加载页面。 3. 生产环境的编译和最小化 项目开发完成后,需要将项目代码编译并打包成可在生产环境中部署的版本。运行"yarn build"命令可以将源代码编译为最小化的静态文件,这些文件通常包含在"dist/"目录下,可以部署到服务器上。 4. 单元测试和端到端测试 为了确保项目的质量和可靠性,单元测试和端到端测试是必不可少的。"yarn test:unit"用于运行单元测试,这是测试单个组件或函数的测试方法。"yarn test:e2e"用于运行端到端测试,这是模拟用户操作流程,确保应用程序的各个部分能够协同工作。 5. 代码规范与自动化修复 "yarn lint"命令用于代码的检查和风格修复。它通过运行ESLint等代码风格检查工具,帮助开发者遵守预定义的编码规范,从而保持代码风格的一致性。此外,它也能自动修复一些可修复的问题。 6. 自定义配置与Vue框架 由于"argos-client:客户端"项目中提到的Vue标签,可以推断该项目使用了Vue.js框架。Vue是一个用于构建用户界面的渐进式JavaScript框架,它允许开发者通过组件化的方式构建复杂的单页应用程序。在项目的自定义配置中,可能需要根据项目需求进行路由配置、状态管理(如Vuex)、以及与后端API的集成等。 7. 压缩包子文件的使用场景 "argos-client-master"作为压缩包子文件的名称,表明该项目可能还涉及打包发布或模块化开发。在项目开发中,压缩包子文件通常用于快速分发和部署代码,或者是在模块化开发中作为依赖进行引用。使用压缩包子文件可以确保项目的依赖关系清晰,并且方便其他开发者快速安装和使用。 通过上述内容的阐述,我们可以了解到在进行"argos-client:客户端"项目的开发时,需要熟悉的一系列操作,包括项目设置、编译和热重装、生产环境编译、单元测试和端到端测试、代码风格检查和修复,以及与Vue框架相关的各种配置。同时,了解压缩包子文件在项目中的作用,能够帮助开发者高效地管理和部署代码。
recommend-type

"互动学习:行动中的多样性与论文攻读经历"

多样性她- 事实上SCI NCES你的时间表ECOLEDO C Tora SC和NCESPOUR l’Ingén学习互动,互动学习以行动为中心的强化学习学会互动,互动学习,以行动为中心的强化学习计算机科学博士论文于2021年9月28日在Villeneuve d'Asq公开支持马修·瑟林评审团主席法布里斯·勒菲弗尔阿维尼翁大学教授论文指导奥利维尔·皮耶昆谷歌研究教授:智囊团论文联合主任菲利普·普雷教授,大学。里尔/CRISTAL/因里亚报告员奥利维耶·西格德索邦大学报告员卢多维奇·德诺耶教授,Facebook /索邦大学审查员越南圣迈IMT Atlantic高级讲师邀请弗洛里安·斯特鲁布博士,Deepmind对于那些及时看到自己错误的人...3谢谢你首先,我要感谢我的两位博士生导师Olivier和Philippe。奥利维尔,"站在巨人的肩膀上"这句话对你来说完全有意义了。从科学上讲,你知道在这篇论文的(许多)错误中,你是我可以依
recommend-type

【SecureCRT高亮规则深度解析】:让日志输出一目了然的秘诀

![【SecureCRT高亮规则深度解析】:让日志输出一目了然的秘诀](https://www.endace.com/assets/images/learn/packet-capture/Packet-Capture-diagram%203.png) 参考资源链接:[SecureCRT设置代码关键字高亮教程](https://wenku.csdn.net/doc/6412b5eabe7fbd1778d44db0?spm=1055.2635.3001.10343) # 1. SecureCRT高亮规则概述 ## 1.1 高亮规则的入门介绍 SecureCRT是一款流行的终端仿真程序,常被用来
recommend-type

在用友U8 UFO报表系统中,如何通过格式管理功能实现报表的格式与样式自定义?

格式管理功能是用友U8 UFO报表系统的一个核心特性,允许用户根据具体需求对报表的布局和样式进行个性化定制。具体操作步骤如下: 参考资源链接:[用友U8 UFO报表系统详解与操作指南](https://wenku.csdn.net/doc/11hy4cw3at?spm=1055.2569.3001.10343) 首先,打开用友U8 UFO报表系统,选择需要编辑的报表文件。 进入报表编辑界面后,点击界面上的‘格式’菜单,这里可以设置报表的各种格式参数。 在格式设置中,用户可以定义报表的字体、大小、颜色、
recommend-type

基于源码的PHP Webshell审查工具介绍

资源摘要信息:"webshell_finder是一款基于源码分析的PHP webshell审查工具。webshell是一种通过网页木马上传的Web后门程序,通常被攻击者用于非法控制遭受攻击的服务器。webshell_finder的原理是遍历指定目录下的所有PHP文件,并对这些文件进行分析,以识别webshell特有的特征函数。特征函数是指webshell中用于执行控制命令、文件操作等恶意行为的函数,如常见的eval、assert、system等。这些函数如果被用于非法目的,则可能构成webshell代码。工具通过识别这些函数并分析其上下文,可以找出具有恶意性质的webshell代码。 目前版本的webshell_finder已经包含了一定数量的特征函数,但作者也提到,通过添加更多的特征函数到特征函数数组中,工具的检测能力将得到加强。这表示,随着特征库的丰富和完善,webshell_finder的检测范围和准确性都有可能得到显著提升。 webshell_finder的使用场景通常是在网站被怀疑遭受了webshell攻击后,进行后门代码的查找和清理工作。它可以辅助安全人员和网站管理员快速定位可能存在的webshell代码,并采取相应的防御或清除措施。 需要注意的是,该工具虽然功能强大,但也不能保证100%检测出所有类型的webshell,因为攻击者可能会使用各种变形或者混淆技术来绕过特征匹配。因此,建议结合其他安全措施和定期的安全审计来提高整体的安全防护水平。 从标签"PHP"可以推测,webshell_finder主要针对PHP编写的网站应用,这是因为PHP是一种广泛使用的服务器端脚本语言,很多网站和Web应用程序都是基于PHP开发的。针对这类应用程序进行安全性审查和防护是十分必要的。 总结来说,webshell_finder作为一个源码级别的webshell审查工具,其核心价值在于能够快速识别并定位出网站中潜在的后门代码,从而帮助提高网站的安全性。随着特征库的不断更新和优化,该工具在未来有可能成为PHP网站安全防护中不可或缺的一部分。"
recommend-type

关系数据表示学习

关系数据卢多维奇·多斯桑托斯引用此版本:卢多维奇·多斯桑托斯。关系数据的表示学习机器学习[cs.LG]。皮埃尔和玛丽·居里大学-巴黎第六大学,2017年。英语。NNT:2017PA066480。电话:01803188HAL ID:电话:01803188https://theses.hal.science/tel-01803188提交日期:2018年HAL是一个多学科的开放存取档案馆,用于存放和传播科学研究论文,无论它们是否被公开。论文可以来自法国或国外的教学和研究机构,也可以来自公共或私人研究中心。L’archive ouverte pluridisciplinaireUNIVERSITY PIERRE和 MARIE CURIE计算机科学、电信和电子学博士学院(巴黎)巴黎6号计算机科学实验室D八角形T HESIS关系数据表示学习作者:Ludovic DOS SAntos主管:Patrick GALLINARI联合主管:本杰明·P·伊沃瓦斯基为满足计算机科学博士学位的要求而提交的论文评审团成员:先生蒂埃里·A·退休记者先生尤尼斯·B·恩