【开源】基于JAVA的电子元器件管理系统
目录
- 一、摘要
- 1.1 项目简介
- 1.2 项目详细录屏
- 二、研究内容
- 三、界面展示
- 3.1 登录&注册&主页
- 3.2 元器件单位模块
- 3.3 元器件仓库模块
- 3.4 元器件供应商模块
- 3.5 元器件品类模块
- 3.6 元器件明细模块
- 3.7 元器件类型模块
- 3.8 元器件采购模块
- 3.9 元器件领用模块
- 3.10 系统基础模块
- 四、项目总结
- 五、免责说明
一、摘要
1.1 项目简介
电子元器件是高校电子实验室进行实验的必备物品,随着电子元器件的种类不断增多,人工管理的方式容易出现错误,对实验室管理员的体验感也不是很好,所以需要开发一套电子元器件管理系统实现对电子元器件的数字化管理需求,其中包括对电子元器件档案的管理和采购入库、学生领用的管理,提高了生产效率,在电子元器件行业数字化转型的背景下,电子元器件系统的建设和应用也具有重要的现实意义和应用价值。本文采用Java等技术构建了电子元器件管理系统的开发环境,完成了电子元器件管理系统的设计研发。最后,针对现有电子元器件系统的不足,提出了优化用户界面、加强数据安全、改进报告系统等改进措施。
1.2 项目详细录屏
二、研究内容
电子元器件管理系统包含元器件单位模块、元器件仓库模块、元器供应商模块、元器件品类模块、元器件明细模块、元器件采购模块、元器件采购审核模块、元器件领用模块、学生元器件申请模块、我的申请模块、申请审核模块,还包含系统自带的用户管理、部门管理、角色管理、菜单管理、日志管理、数据字典管理、文件管理、图表展示等基础模块 ,电子元器件管理系统基于角色的访问控制,可将权限精确到按钮级别,适合设计精确的权限约束需求。
电子元器件管理系统的主要任务是电子元器件综合管理、综合规划、合理采购、保持正确管理、科学管理和及时更新。充分利用电子元器件的使用效率及其最佳效益。提高教育质量,加强实验室电子元器件管理,为此电子元器件管理系统应包括以下功能。
- 元器件类型模块,实现对元器件类型的增加、删除、编辑和模拟查询,要求实时统计系统中元器件类型的件数。
- 元器件档案模块,实现对元器件档案的增加、删除、编辑和模拟查询,要求支持元器件图片的上传和预览。
- 元器件采购模块,实现对元器件的采购,采购需要审核,仓管员采购完成后可一键入库,库存回写元器件档案模块。
- 用户档案管理,实现对终端用户数据的维护,包括姓名、手机号、头像等数据,员工可自己修改密码。
- 角色管理,采用基于角色的访问控制,对于管理员、仓管员分配不同的菜单权限。
- 日志管理,用户对元器件相关模块的操作数据需要自动化记录,管理员可在后台查询,日志需要包括操作人、操作时间和操作的内容。
根据项目要求,元器件模块前端采用Vue.js实现,系统后端要求采用springBoot实现,采用mybatisPlus读写数据库,数据库采用MySQL,采用Redis中间件作为数据缓存,最终实现电子元器件管理系统的设计、开发和测试。
前端:Vue 2.7.10
后端:Spring Boot 3.1.10
数据库:MySQL 8.0.31
-
元器件类型模块
元器件类型的研究意义在于,它对电子元器件行业的产品开发和市场竞争具有重要影响。首先,根据元器件的类型,市场需求、价格、利润率等方面存在差异,通过研究消费者的购买行为和偏好,以及市场竞争和趋势,可以确定公司应该开发什么类型的元器件,并制定适当的产品规划和定价策略。对零件类型的研究也可以帮助公司了解市场的多样性和可变性,并很好地适应市场需求和趋势。例如,新兴的消费市场,一个特殊群体的消费需求,都需要用不同类型的零件来满足。因此,通过持续的零件类型研究,企业可以抓住市场机遇,不断创新和优化产品,提高市场份额和品牌知名度。 -
元器件仓库模块
元器件仓库模块的研究意义在于对企业的元器件管理和物流效率产生重要影响。首先,元器件仓库是企业储存、储存和配送元器件的重要部门。通过研究元器件仓库的设计、布局和管理策略,可以优化元器件仓库的运营流程,提高元器件的存储密度和运输效率,降低运营成本。元器件仓库模块还帮助公司跟踪元器件供应链信息,更好地了解元器件市场趋势和库存状况。例如,通过元器件编码系统、RFID设备等技术手段,实现元器件的小型化管理和跟踪,以确保元器件的来源和质量可追溯,从而为企业的采购计划和库存管理提供参考依据。 -
元器件档案模块
研究组件元器件档案的意义在于,在企业的元器件管理和决策中发挥着重要作用。首先,元器件包含有关零件的基本信息,例如零件名称、型号、规格、制造商和性能参数。通过建立完善的元器件档案,对元器件进行分类、分类和管理,可以提高元器件管理的效率和准确性。例如,通过分析元器件库存数据,可以确定哪些元器件需要增加采购,哪些零件需要减少库存,以及采购路线是否需要优化,从而降低采购成本,提高元器件库存周转率。 -
元器件采购模块
元器件是电子产品的基本元器件,包括电阻器、电容器、晶体管、集成电路等。没有这些元器件,就无法制造出完整的电子产品。因此,企业需要采购元器件,以保证生产和销售的正常运行。元器件采购是保证生产的必要条件。当公司缺乏所需的零件时,可能会影响产品的速度和质量,甚至导致生产线停工。因此,及时采购必要的元器件是维持生产运行的必要措施,元器件采购也有助于公司降低生产成本。通过考虑元器件价格、质量和供应路线等因素,公司可以选择更经济、高效和稳定的元器件来源,并降低不必要的成本。元器件采购也是企业市场竞争力的一个重要因素。在竞争激烈的市场环境中,企业需要不断优化元器件采购策略,提高产品质量和性能,降低生产成本,实现可持续发展目标。 -
元器件领用模块
元器件的领用意义在于它在企业元器件管理和成本管理中具有重要作用。首先,元器件领用系统的实施可以有效监控元器件库存的流向,及时发现库存异常和损失,提高元器件管理的效率和准确性,还可以帮助公司管理元器件成本。通过比较每个部门或工人收到的元器件的数量和质量,可以避免由于过度使用或滥用元器件而造成的浪费和不必要的成本支出,此外,元器件数据的统计和分析可以优化零件采购计划,进一步降低零件成本。元器件领用模块带来了很多的效率和便利。
三、界面展示
3.1 登录&注册&主页
@RequestMapping(value = "/regist", method = RequestMethod.POST)
@ApiOperation(value = "注册用户")
public Result<Object> regist(@Valid User u){u.setEmail(u.getMobile() + "@qq.com");QueryWrapper<User> userQw = new QueryWrapper<>();userQw.and(wrapper -> wrapper.eq("username", u.getUsername()).or().eq("mobile",u.getMobile()));if(iUserService.count(userQw) > 0L) {return ResultUtil.error("登录账号/手机号重复");}String encryptPass = new BCryptPasswordEncoder().encode(u.getPassword());u.setPassword(encryptPass).setType(0);iUserService.saveOrUpdate(u);QueryWrapper<Role> roleQw = new QueryWrapper<>();roleQw.eq("default_role",true);List<Role> roleList = iRoleService.list(roleQw);if(roleList.size() > 0){for(Role role : roleList) {iUserRoleService.saveOrUpdate(new UserRole().setUserId(u.getId()).setRoleId(role.getId()));}}return ResultUtil.data(u);
}
3.2 元器件单位模块
@RequestMapping(value = "/getByPage", method = RequestMethod.GET)
@ApiOperation(value = "查询元器件计量单位")
public Result<IPage<AdminAssetUnit>> getByPage(@ModelAttribute AdminAssetUnit unit, @ModelAttribute PageVo page) {QueryWrapper<AdminAssetUnit> qw = new QueryWrapper<>();if(!ZwzNullUtils.isNull(unit.getName())) {qw.like("name",unit.getName());}if(!ZwzNullUtils.isNull(unit.getBm())) {qw.like("bm",unit.getBm());}return new ResultUtil<IPage<AdminAssetUnit>>().setData(iAdminAssetUnitService.page(PageUtil.initMpPage(page),qw));
}
@RequestMapping(value = "/insert", method = RequestMethod.POST)
@ApiOperation(value = "新增元器件计量单位")
public Result<AdminAssetUnit> insert(AdminAssetUnit adminAssetUnit){int number = (int)iAdminAssetUnitService.count() + 1;adminAssetUnit.setBm("DW" + number);if(iAdminAssetUnitService.saveOrUpdate(adminAssetUnit)){return new ResultUtil<AdminAssetUnit>().setData(adminAssetUnit);}return ResultUtil.error();
}@RequestMapping(value = "/update", method = RequestMethod.POST)
@ApiOperation(value = "编辑元器件计量单位")
public Result<AdminAssetUnit> update(AdminAssetUnit adminAssetUnit){if(iAdminAssetUnitService.saveOrUpdate(adminAssetUnit)){return new ResultUtil<AdminAssetUnit>().setData(adminAssetUnit);}return ResultUtil.error();
}@RequestMapping(value = "/delByIds", method = RequestMethod.POST)
@ApiOperation(value = "删除元器件计量单位")
public Result<Object> delAllByIds(@RequestParam String[] ids){for(String id : ids){iAdminAssetUnitService.removeById(id);}return ResultUtil.success();
}
3.3 元器件仓库模块
@RequestMapping(value = "/getByPage", method = RequestMethod.GET)
@ApiOperation(value = "查询元器件仓库档案")
public Result<IPage<AdminAssetWare>> getByPage(@ModelAttribute AdminAssetWare ware, @ModelAttribute PageVo page){QueryWrapper<AdminAssetWare> qw = new QueryWrapper<>();if(!ZwzNullUtils.isNull(ware.getName())) {qw.like("name",ware.getName());}if(!ZwzNullUtils.isNull(ware.getAddress())) {qw.like("address",ware.getAddress());}if(!ZwzNullUtils.isNull(ware.getAdminName())) {qw.and(wrapper -> wrapper.eq("admin_name", ware.getAdminName()).or().eq("department",ware.getAdminName()));}IPage<AdminAssetWare> data = iAdminAssetWareService.page(PageUtil.initMpPage(page),qw);return new ResultUtil<IPage<AdminAssetWare>>().setData(data);
}
@RequestMapping(value = "/insert", method = RequestMethod.POST)
@ApiOperation(value = "新增元器件仓库档案")
public Result<AdminAssetWare> insert(AdminAssetWare adminAssetWare){if(!Objects.equals(1,adminAssetWare.getAttributionType())) {adminAssetWare.setAttributionType(0);QueryWrapper<User> qw = new QueryWrapper<>();qw.eq("nickname",adminAssetWare.getAdminName());qw.eq("status","0");List<User> rosterUserList = iUserService.list(qw);if(rosterUserList.size() < 1) {return ResultUtil.error("仓管员不存在或离职");}adminAssetWare.setJobNumber(rosterUserList.get(0).getUsername());}// 判断名称重复QueryWrapper<AdminAssetWare> qw = new QueryWrapper<>();qw.eq("name",adminAssetWare.getName());if(iAdminAssetWareService.count(qw) > 0L) {return ResultUtil.error(adminAssetWare.getName() + "仓库已存在,不能重复添加");}iAdminAssetWareService.saveOrUpdate(adminAssetWare);return ResultUtil.success();
}
3.4 元器件供应商模块
@RequestMapping(value = "/getByPage", method = RequestMethod.GET)
@ApiOperation(value = "查询元器件供应商")
public Result<IPage<AdminAssetSupplier>> getByPage(@ModelAttribute AdminAssetSupplier supplier, @ModelAttribute PageVo page){QueryWrapper<AdminAssetSupplier> qw = new QueryWrapper<>();if(!ZwzNullUtils.isNull(supplier.getName())) {qw.like("name",supplier.getName());}if(!ZwzNullUtils.isNull(supplier.getType())) {qw.like("type",supplier.getType());}if(!ZwzNullUtils.isNull(supplier.getAddress())) {qw.like("address",supplier.getAddress());}return new ResultUtil<IPage<AdminAssetSupplier>>().setData(iAdminAssetSupplierService.page(PageUtil.initMpPage(page),qw));
}
@RequestMapping(value = "/insert", method = RequestMethod.POST)
@ApiOperation(value = "新增元器件供应商")
public Result<AdminAssetSupplier> insert(AdminAssetSupplier adminAssetSupplier){iAdminAssetSupplierService.saveOrUpdate(adminAssetSupplier);return ResultUtil.success();
}@RequestMapping(value = "/update", method = RequestMethod.POST)
@ApiOperation(value = "编辑元器件供应商")
public Result<AdminAssetSupplier> update(AdminAssetSupplier adminAssetSupplier){iAdminAssetSupplierService.saveOrUpdate(adminAssetSupplier);return ResultUtil.success();
}@RequestMapping(value = "/delByIds", method = RequestMethod.POST)
@ApiOperation(value = "删除元器件供应商")
public Result<Object> delByIds(@RequestParam String[] ids){for(String id : ids){iAdminAssetSupplierService.removeById(id);}return ResultUtil.success();
}
3.5 元器件品类模块
@RequestMapping(value = "/getByPage", method = RequestMethod.GET)
@ApiOperation(value = "查询元器件品类")
public Result<IPage<AdminAsset>> getByPage(@ModelAttribute AdminAsset asset, @ModelAttribute PageVo page) {QueryWrapper<AdminAsset> qw = new QueryWrapper<>();if(!ZwzNullUtils.isNull(asset.getType())) {qw.eq("type",asset.getType());}if(!ZwzNullUtils.isNull(asset.getType2())) {qw.eq("type2",asset.getType2());}if(!ZwzNullUtils.isNull(asset.getCode())) {qw.like("code",asset.getCode());}if(!ZwzNullUtils.isNull(asset.getName())) {qw.like("name",asset.getName());}if(!ZwzNullUtils.isNull(asset.getGg())) {qw.like("gg",asset.getGg());}IPage<AdminAsset> data = iAdminAssetService.page(PageUtil.initMpPage(page),qw);for (AdminAsset vo : data.getRecords()) {QueryWrapper<AdminAssets> itemQw = new QueryWrapper<>();itemQw.eq("asset_id",vo.getId());itemQw.eq("status",0);vo.setCount(iAdminAssetsService.count(itemQw));}return new ResultUtil<IPage<AdminAsset>>().setData(data);
}
@RequestMapping(value = "/fastInsert", method = RequestMethod.POST)
@ApiOperation(value = "快速新增元器件品类")
public Result<AdminAsset> fastInsert(@RequestParam String name,@RequestParam String type,@RequestParam String type2,@RequestParam String modal){QueryWrapper<AdminAsset> qw = new QueryWrapper<>();qw.eq("name",name);qw.eq("xh",modal);if(iAdminAssetService.count(qw) > 0) {return ResultUtil.error("元器件品类已存在,无需重复添加");}AdminAsset as = new AdminAsset();as.setName(name);as.setType(type);as.setType2(type2);as.setGg("");as.setXh(modal);as.setJldw("个");as.setXsj(BigDecimal.ZERO);as.setImageUrl("");as.setRemark("");iAdminAssetService.saveOrUpdate(as);return new ResultUtil<AdminAsset>().setData(as);
}
3.6 元器件明细模块
3.7 元器件类型模块
3.8 元器件采购模块
@RequestMapping(value = "/getByPage", method = RequestMethod.GET)
@ApiOperation(value = "查询元器件采购")
public Result<IPage<AdminAssetsBuy>> getByPage(@ModelAttribute AdminAssetsBuy buy, @ModelAttribute PageVo page) {QueryWrapper<AdminAssetsBuy> qw = new QueryWrapper<>();qw.eq("user_id",securityUtil.getCurrUser().getId());if(!ZwzNullUtils.isNull(buy.getName())) {qw.like("name",buy.getName());}if(!ZwzNullUtils.isNull(buy.getReason())) {qw.like("reason",buy.getReason());}IPage<AdminAssetsBuy> data = iAdminAssetsBuyService.page(PageUtil.initMpPage(page),qw);return new ResultUtil<IPage<AdminAssetsBuy>>().setData(data);
}
@RequestMapping(value = "/submitData", method = RequestMethod.POST)
@ApiOperation(value = "提交元器件采购")
public Result<Object> submitData(@RequestParam String[] ids,@RequestParam String reason,@RequestParam String supplierId){AdminAssetSupplier supplier = iAdminAssetSupplierService.getById(supplierId);if(supplier == null) {return ResultUtil.error("供应商不存在");}List<AdminAssetsBuy> voList = new ArrayList<>();for(String id : ids){AdminAssetsBuy buy = iAdminAssetsBuyService.getById(id);if(buy == null) {return ResultUtil.error("id = " + id + "不存在");}if(Objects.equals(0,buy.getSubmitFlag())) {voList.add(buy);}}for (AdminAssetsBuy vo : voList) {vo.setSubmitFlag(1);vo.setOpen(supplier.getOpen());vo.setPushName(supplier.getUserName());vo.setCode(supplier.getCode());vo.setRise(supplier.getRise());vo.setSupplierId(supplier.getId());vo.setSupplierName(supplier.getName());iAdminAssetsBuyService.saveOrUpdate(vo);}return ResultUtil.success();
}
@RequestMapping(value = "/auditData", method = RequestMethod.POST)
@ApiOperation(value = "审核元器件采购")
public Result<Object> auditData(@RequestParam String[] ids,@RequestParam int status){for(String id : ids){AdminAssetsBuy buy = iAdminAssetsBuyService.getById(id);if(buy == null || !Objects.equals(0,buy.getAuditFlag())) {continue;}User user = iUserService.getById(buy.getUserId());if(user == null) {continue;}buy.setAuditFlag(status);// 通过if(Objects.equals(1,status)) {buy.setQuantity2(buy.getQuantity());}iAdminAssetsBuyService.saveOrUpdate(buy);}return ResultUtil.success();
}
@RequestMapping(value = "/inWare", method = RequestMethod.POST)
@ApiOperation(value = "入库元器件采购")
public Result<Object> inWare(@RequestParam String id,@RequestParam int quantity,@RequestParam String date,@RequestParam String warehouse){AdminAssetsBuy buy = iAdminAssetsBuyService.getById(id);if(buy == null) {return ResultUtil.error("采购单不存在");}AdminAssetWare ware = iAdminAssetWareService.getById(warehouse);if(ware == null) {return ResultUtil.error("仓库不存在");}if(ZwzNullUtils.isNull(date)) {date = DateUtil.today();}QueryWrapper<AdminAssets> qw = new QueryWrapper<>();qw.eq("asset_id",buy.getAssetId());Long assetsCount = iAdminAssetsService.count(qw);for(int i = 1 ; i <= quantity; i ++) {AdminAssets adminAssets = new AdminAssets();adminAssets.setName(buy.getName());adminAssets.setModel(buy.getModel());adminAssets.setAssetId(buy.getAssetId());adminAssets.setCode("ZC" + buy.getAssetCode() + String.format("%04d", assetsCount + i));adminAssets.setUnit(buy.getUnit());adminAssets.setBuyUser(buy.getUserName());adminAssets.setBuyNumber(buy.getId());adminAssets.setBuyDate(date);adminAssets.setWarehouse(ware.getId());adminAssets.setWarehouseName(ware.getName());adminAssets.setGiveType(0);adminAssets.setGiveId("");adminAssets.setGiveName("");adminAssets.setOutFlag(0);adminAssets.setOutWork("");adminAssets.setOutTime("");adminAssets.setStatus(0);adminAssets.setDestroyName("");adminAssets.setDestroyTime("");adminAssets.setApplyFlag(0);adminAssets.setApplyUser("");adminAssets.setApplyTime("");iAdminAssetsService.saveOrUpdate(adminAssets);}if(BigDecimal.valueOf(quantity).compareTo(buy.getQuantity())< 0) {buy.setQuantity2(buy.getQuantity2().subtract(BigDecimal.valueOf(quantity)));buy.setWareFlag(1);} else {buy.setQuantity2(BigDecimal.ZERO);buy.setWareFlag(2);}iAdminAssetsBuyService.saveOrUpdate(buy);return ResultUtil.success();
}
3.9 元器件领用模块
@RequestMapping(value = "/apply", method = RequestMethod.POST)
@ApiOperation(value = "申请元器件")
public Result<Object> apply(@RequestParam String id){User user = securityUtil.getCurrUser();AdminAssets asset = iAdminAssetsService.getById(id);if(asset == null) {return ResultUtil.error("元器件不存在");}if(!Objects.equals(0,asset.getOutFlag())) {return ResultUtil.error("手慢啦!元器件已被" + asset.getGiveName() + "领用,请刷新");}asset.setApplyFlag(1);asset.setApplyUser(user.getNickname());asset.setApplyTime(DateUtil.now());iAdminAssetsService.saveOrUpdate(asset);return ResultUtil.success();
}
3.10 系统基础模块
用户管理模块如下图所示。
部门管理模块如下图所示。
文件管理模块如下图所示。
角色权限管理模块如下图所示。
日志管理模块如下图所示。
个人中心模块如下图所示。
四、项目总结
在电子元件管理系统的开发中,第一步是确定元件系统的功能需求和设计概念的进展。完成对组件企业的业务流程和数据模型的分析,确定需要实现的系统的管理目标和数据结构,然后选择技术平台和开发工具的进展。
选择Java等技术平台,构建系统开发环境,开始系统开发和测试。然后完成系统的开发和测试进度,根据系统的功能需求和设计理念,完成系统主要功能模块的开发和检测,进行基础调优和性能测试,最终完成现有系统。
针对不足,制定了改进建议,从用户界面、数据安全、报告系统等方面进行改进,以提高系统的易用性、稳定性和数据质量,从而使企业的管理决策更加完整,并提供准确的数据支持。在未来,将对开发电子元器件管理系统的更多模块进行开发和实现。
五、免责说明
- 本项目仅供个人学习使用,商用授权请联系博主,否则后果自负。
- 博主拥有本软件构建后的应用系统全部内容所有权及独立的知识产权,拥有最终解释权。
- 如有问题,欢迎在仓库 Issue 留言,看到后会第一时间回复,相关意见会酌情考虑,但没有一定被采纳的承诺或保证。
下载本系统代码或使用本系统的用户,必须同意以下内容,否则请勿下载!
- 出于自愿而使用/开发本软件,了解使用本软件的风险,且同意自己承担使用本软件的风险。
- 利用本软件构建的网站的任何信息内容以及导致的任何版权纠纷和法律争议及后果和博主无关,博主对此不承担任何责任。
- 在任何情况下,对于因使用或无法使用本软件而导致的任何难以合理预估的损失(包括但不仅限于商业利润损失、业务中断与业务信息丢失),博主概不承担任何责任。
- 必须了解使用本软件的风险,博主不承诺提供一对一的技术支持、使用担保,也不承担任何因本软件而产生的难以预料的问题的相关责任。
相关文章:

【开源】基于JAVA的电子元器件管理系统
目录 一、摘要1.1 项目简介1.2 项目详细录屏 二、研究内容三、界面展示3.1 登录&注册&主页3.2 元器件单位模块3.3 元器件仓库模块3.4 元器件供应商模块3.5 元器件品类模块3.6 元器件明细模块3.7 元器件类型模块3.8 元器件采购模块3.9 元器件领用模块3.10 系统基础模块 …...

足底筋膜炎怎么治疗治愈
足底筋膜炎又称为跖筋膜炎,跖筋膜主要在足弓下方,它维持足弓稳定性,对于喜欢长期长跑、跳远,或者越野运动,或者部队中的士兵进行拉练,还有需要久坐或者久站的人群中,容易发生跖筋膜炎。治疗方法…...

Keil工程忽略文件.gitignore、自动删除脚本:keilkilll.bat、自动生成目录文件列表脚本
Keil工程忽略文件:.gitignore 忽略规则 *.rar *.o *.d *.crf *.htm *.dep *.map *.bak *.lnp *.lst *.ini *.iex *.sct *.scvd *.dbg* *.uvguix.* *Log.*#忽略.gitignore根目录下的文件夹,根据自己的需要修改 RTE/ Templates/ Examples/ OBJ/#不能忽略…...

软考高级职称哪个好考?明确给你答案
软考考试分为初、中、高三级,其中高级5个方向分别为系统分析师、信息系统项目管理师、网络规划设计师、系统架构设计师、系统规划与管理师。软考高级职称考什么好?有很多人是因为要评高级职称而选择参考软考高级资格考试,那么软考高级里哪个资…...

智能客服外包服务适用于哪些行业?
在当今快节奏的商业环境下,企业需要更高效、更智能且更灵活的客户服务解决方案。而智能客服外包服务正是满足这一需求的利器。不仅可以帮助企业提升客户服务的品质和效率,还能降低企业的运营成本。智能客服外包服务适用于哪些行业呢? 1.电子…...

数字化企业各业务模块模型
1.计划 1.1采购计划执行情况 序号 采购计划号 采购订单号 业务员 供应商 物料 数量 金额 计划入库日期 实际入库日期 状态 针对企业执行中或者未关闭的采购计划进行统计与分析,主要目的在于引领企业员工与领导关注长期在途的采购…...

WPF动画小知识
一、动画合集 创建一个Storyboard演示画板,在画板里对动画进行定义与处理。 常见动画类型 提醒:更多介绍可查看microsoft提供的相关文档 DoubleAnimation //普通Double型控制动画 DoubleAnimationUsingKeyFrames //Dou…...

数据结构 顺序表和链表
1.线性表 线性表(linear list)是n个具有相同特性的数据元素的有限序列 线性表是一种在实际中广泛使用的数据结构,常见的线性表:顺序表、链表、栈、队列、字符串.. 线性表在逻辑上是线性结构,也就说是连续的一条直线…...

LMI相机配置步骤,使用Gocator2550相机
在此之前可以先浏览我编写的相机SDK通用类和LMISDK,进行配套观看 https://blog.csdn.net/m0_51559565/article/details/134404394 //LMI相机SDK https://blog.csdn.net/m0_51559565/article/details/134403745 //相机通用类1.启动LMI加速器 LMI加速器用于将相机…...

掌握Python中的控制流语句:break, continue, quit的应用技巧详解
引言 在Python编程中,控制流语句是非常重要的一部分,它们可以帮助我们控制程序的执行流程。其中,break、continue和quit是常用的控制流语句,它们可以在循环中起到关键作用。本文将详细介绍这些控制流语句的应用技巧,帮…...

TS手动编译和自动编译方法
把 TS 文件编译成 JS 文件 安装 npm i -g typescript检查是否安装成功 tsc -v方法一 先通过 tsc 把 .ts 文件编译成 .js 文件,再通过 node 把 .js 文件运行 方法二 通过监视配置页面 初始化 tsc --init自动生成一个tsconfig.json 文件 点击进入tsconfig.js…...

【Hello Go】Go语言运算符
Go语言运算符 算术运算符关系运算符逻辑运算符位运算符赋值运算符其他运算符运算符优先级 算术运算符 如果之前没有其他语言基础的小伙伴可以参考下我之前写的C语言运算符讲解 这里主要讲解下Go和C运算符的不同点 – 运算符 Go语言中只有后置 和后置– var a int 5a--fmt.P…...

理解 JMeter 聚合报告(Aggregate Report)
Aggregate Report 是 JMeter 常用的一个 Listener,中文被翻译为“聚合报告”。今天再次有同行问到这个报告中的各项数据表示什么意思,顺便在这里公布一下,以备大家查阅。 如果大家都是做Web应用的性能测试,例如只有一个登录的请求…...

深度学习之pytorch第一课
学习使用pytorch,然后进行简单的线性模型的训练与保存 学习代码如下: import numpy as np import torch import torch.nn as nn x_value [i for i in range(11)] x_train np.array(x_value,dtypenp.float32) print(x_train.shape) x_train x_train.r…...

企业传统纸质设备维修方式的痛点以及解决方案
传统的纸质设备维修方式有很多痛点: 数据更新和访问的低效率:传统的纸质记录方法在更新和检索数据时效率极低。这种方式无法实时更新设备的维修状态,导致管理层和维修人员无法及时获取最新信息,影响决策的速度和质量。 记录的易…...

vue2 - SuperMap3D实现自定义标记点位和自定义弹窗功能
文章目录 🍉开发环境🍉实现思路🍉代码封装🍍1:src/utils 下创建 extendMap文件如下🍍2:src/utils/extendMap/model/createMap.js 文件相关代码🍍3:src/utils/extendMap/model/bubble.js 文件相关代码🍍4:src/utils/extendMap/model\dragEntity.js 文件相关代…...

vue中通过.style.animationDuration属性,根据数据长度动态设定元素的纵向滚动时长的demo
根据数据长度动态设定元素的animation 先看看效果,是一个纯原生div标签加上css实现的表格纵向滚动动画: 目录 根据数据长度动态设定元素的animationHTMLjs逻辑1、判断是数据长度是否达到滚动要求2、根据数据长度设置滚动速度 Demo完整代码 HTML 1、确…...

(五)七种元启发算法(DBO、LO、SWO、COA、LSO、KOA、GRO)求解无人机路径规划MATLAB
一、七种算法(DBO、LO、SWO、COA、LSO、KOA、GRO)简介 1、蜣螂优化算法DBO 蜣螂优化算法(Dung beetle optimizer,DBO)由Jiankai Xue和Bo Shen于2022年提出,该算法主要受蜣螂的滚球、跳舞、觅食、偷窃和繁…...

深度学习之基于Pytorch框架的MNIST手写数字识别
欢迎大家点赞、收藏、关注、评论啦 ,由于篇幅有限,只展示了部分核心代码。 文章目录 一项目简介 二、功能三、系统四. 总结 一项目简介 MNIST是一个手写数字识别的数据集,是深度学习中最常用的数据集之一。基于Pytorch框架的MNIST手写数字识…...

zabbix的服务器端 server端安装部署
zabbix的服务器端 server 主机iplocalhost(centos 7)192.168.10.128 zabbix官网部署教程 但是不全,建议搭配这篇文章一起看 zabbixAgent部署 安装mysql 所有配置信息和Zabbix收集到的数据都被存储在数据库中。 下载对应的yum源 yum ins…...

css3 初步了解
1、css3的含义及简介 简而言之,css3 就是 css的最新标准,使用css3都要遵循这个标准,CSS3 已完全向后兼容,所以你就不必改变现有的设计, 2、一些比较重要的css3 模块 选择器 1、标签选择器,也称为元素选择…...

【实战经验】MT4外汇交易指南:新手如何制定交易计划?
在外汇交易中,制定一个合理的交易计划至关重要。一个良好的交易计划可以帮助您规避风险、提高交易效率,甚至在市场波动时保持冷静。作为资深外汇交易专家,我将分享一些制定交易计划的重要性、技术分析工具的应用以及风险管理策略等方面的内容…...

Pikachu漏洞练习平台之CSRF(跨站请求伪造)
本质:挟制用户在当前已登录的Web应用程序上执行非本意的操作(由客户端发起) 耐心看完皮卡丘靶场的这个例子你就明白什么是CSRF了 CSRF(get) 使用提示里给的用户和密码进行登录(这里以lili为例) 登录成功后显示用户…...

Python 如何实现 Strategy 策略设计模式?什么是 Strategy 策略设计模式?
策略模式(Strategy Design Pattern)是一种对象行为型设计模式,它定义了一系列算法,并使得这些算法可以相互替换,使得客户端代码可以独立于算法的变化而变化。策略模式属于对象行为模式。 主要角色: 策略接口…...

hadoop 大数据集群环境配置 配置hadoop配置文件 hadoop(七)
1. 虚拟机的三台机器分别以hdfs 存储, mapreduce计算,yarn调度三个方面进行集群配置 hadoop 版本3.3.4 官网:Hadoop – Apache Hadoop 3.3.6 jdk 1.8 三台机器尾号为:22, 23, 24。(没有用hadoop102, 103,10…...

解决 requests 库中 Post 请求路由无法正常工作的问题
解决 requests 库中 Post 请求路由无法正常工作的问题是一个常见的问题,也是很多开发者在使用 requests 库时经常遇到的问题。本文将介绍如何解决这个问题,以及如何预防此类问题的发生。 问题背景 用户报告,Post 请求路由在这个库中不能正常…...

Jenkins入门——安装docker版的Jenkins 配置mvn,jdk等 使用案例初步 遇到的问题及解决
前言 Jenkins是开源CI&CD软件领导者, 提供超过1000个插件来支持构建、部署、自动化, 满足任何项目的需要。 官网:https://www.jenkins.io/zh/ 本篇博客介绍docker版的jenkins的安装和使用,maven、jdk,汉语的配置…...

一文搞定以太网PHY、MAC及其通信接口
本文主要介绍以太网的 MAC 和 PHY,以及之间的 MII(Media Independent Interface ,媒体独立接口)和 MII 的各种衍生版本——GMII、SGMII、RMII、RGMII等。 简介 从硬件的角度看,以太网接口电路主要由MAC(M…...

【JavaEE】Servlet API 详解(HttpServletResponse类方法演示、实现自动刷新、实现自动重定向)
一、HttpServletResponse HttpServletResponse表示一个HTTP响应 Servlet 中的 doXXX 方法的目的就是根据请求计算得到相应, 然后把响应的数据设置到 HttpServletResponse 对象中 然后 Tomcat 就会把这个 HttpServletResponse 对象按照 HTTP 协议的格式, 转成一个字符串, 并通…...

QML19、QML 和 C++ 之间的数据类型转换
QML 和 C++ 之间的数据类型转换 在 QML 和 C++ 之间交换数据值时,QML 引擎会将它们转换为具有适合在 QML 或 C++ 中使用的正确数据类型。 这要求交换的数据是引擎可识别的类型。 QML 引擎为大量 Qt C++ 数据类型提供内置支持。 此外,自定义 C++ 类型可以向 QML 类型系统注册,…...