【ArcGIS技巧】根据地块、界址点图层生成界址线
"农经权二轮延包我已经写的差不多了,需要的一些生成四至、分割地块的功能也分享了替代的插件。前面刚分享完界址点的生成,今天分享界址线的生成,有需要的自取,至此,基本可以用这些功能完成出成果工作。"
1、工具使用
在使用前,先确保有地块(DK.shp)要素图层,且包含字段“DKBM”、“ZJRXM”;界址点(JZD.shp)要素图层(含字段"DKBM", "JZDH")。
插件因为生成界址线比较复杂,而且生成JZX.shp图层包含了:"DKBM"、“QZJDH”、“ZJZDH”、“JZXSM”,特别是“JZXSM”字段比较复杂,所以生成的时间稍微长些,请注意等待。
下载后记得加载py文件,不会的参考:【ArcGIS技巧】分享个判断是否基本农田的工具。
2、脚本逻辑
脚本的生成逻辑大致分为三步:1、先利用地块要素图层生成只要两个点的直线,生成DKBM、PLDWQLR字段;2、根据生成DKBM、PLDWQLR字段合并直线,因为前面界址点生成简化了面,所以要确保每个界址线的起止点都在界址线图层中,再根据界址点去截断界址线;3、根据界址点的JZDH以及界址线的长度与方位等,生成“QZJDH”、“ZJZDH”、“JZXSM”字段内容。
值得注意的是:工具的py文件,在pycharm等解析器中写完后,需要用文本文件编辑器打开,另存文件覆盖原来的.py文件,编码选ANSI格式,只有这样,其中一些中文什么的才会执行时不报错。
3、具体代码
工具的具体代码如下:
# -*- coding: utf-8 -*-
import arcpy
import os
from collections import defaultdict
import tempfile
import math
import sys
reload(sys)
sys.setdefaultencoding('utf-8')
arcpy.env.workspace = u"C:\\data"
arcpy.env.overwriteOutput = True
arcpy.env.qualifiedFieldNames = Falsedk_shp = u"C:\\data\\DK.shp"
jzd_path = u"C:\\data\\JZD.shp"
output_folder = u"C:\\data\\new"# 中间文件路径
temp_folder = tempfile.mkdtemp()
jzx1_path = os.path.join(temp_folder, u"JZX1.shp")
dissolve_path = os.path.join(temp_folder, u"dissolved.shp")
rounded_points = os.path.join(temp_folder, u"rounded_points.shp")def create_jzx():# 验证必须字段存在required_fields = ["DKBM", "ZJRXM"]actual_fields = [f.name for f in arcpy.ListFields(dk_shp)]missing = [f for f in required_fields if f not in actual_fields]if missing:raise arcpy.ExecuteError(u"缺失必要字段:{}".format("/".join(missing)))# ====================== 创建输出要素 ======================sr = arcpy.Describe(dk_shp).spatialReferencearcpy.CreateFeatureclass_management(out_path=temp_folder,out_name=os.path.basename(jzx1_path),geometry_type="POLYLINE",spatial_reference=sr)# 添加字段arcpy.AddField_management(jzx1_path, "DKBM", "TEXT", field_length=100)arcpy.AddField_management(jzx1_path, "PLDWZJR", "TEXT", field_length=255)# ====================== 构建DKBM-ZJRXM映射 ======================dk_zjr_map = {}with arcpy.da.SearchCursor(dk_shp, ["DKBM", "ZJRXM"]) as cursor:for row in cursor:dk_zjr_map[row[0]] = row[1]# ====================== 主处理逻辑 ======================line_dict = defaultdict(set)arcpy.AddMessage(u"正在采集边界线段...")# 第一次遍历:收集所有边界线段with arcpy.da.SearchCursor(dk_shp, ["OID@", "SHAPE@", "DKBM"]) as cursor:for row in cursor:geom = row[1]dkbm = row[2]# 分解多边形边界线for part in geom.getPart():for i in range(len(part) - 1):pt1 = part[i]pt2 = part[i + 1]# 标准化线段方向(避免反向重复)if (pt1.X, pt1.Y) > (pt2.X, pt2.Y):pt1, pt2 = pt2, pt1# 生成唯一标识(精确到毫米)line_key = (round(pt1.X, 3), round(pt1.Y, 3),round(pt2.X, 3), round(pt2.Y, 3))line_dict[line_key].add(dkbm)# ====================== 写入结果 ======================arcpy.AddMessage(u"正在生成界址线...")with arcpy.da.InsertCursor(jzx1_path, ["SHAPE@", "DKBM", "PLDWZJR"]) as i_cursor:# 第二次遍历:处理相邻地块逻辑for line_key, dkbms in line_dict.iteritems():pt1 = arcpy.Point(line_key[0], line_key[1])pt2 = arcpy.Point(line_key[2], line_key[3])line = arcpy.Polyline(arcpy.Array([pt1, pt2]), sr)# 处理DKBM字段(按字母排序)sorted_dkbms = sorted(dkbms, key=lambda x: str(x))dkbm_str = "/".join(sorted_dkbms)# 处理PLDWZJR字段if len(sorted_dkbms) == 1:zjrxm = u"无"else:# 取"/"后面所有地块的ZJRXMzjrxm_list = []for dk in sorted_dkbms[1:]: # 从第二个开始if dk in dk_zjr_map:zjrxm_list.append(dk_zjr_map[dk])zjrxm = "/".join(zjrxm_list) if zjrxm_list else u"无"i_cursor.insertRow([line, dkbm_str, zjrxm])arcpy.AddMessage(u"处理完成!输出路径:{}".format(jzx1_path))create_jzx()try:# ===== 阶段1:合并界址线 =====arcpy.Dissolve_management(in_features=jzx1_path,out_feature_class=dissolve_path,dissolve_field=["DKBM", "PLDWZJR"],multi_part="SINGLE_PART")# ===== 阶段2:创建精确坐标点 =====arcpy.CreateFeatureclass_management(temp_folder,os.path.basename(rounded_points),"POINT",spatial_reference=arcpy.Describe(jzd_path).spatialReference)# 插入舍入坐标点with arcpy.da.SearchCursor(jzd_path, ["SHAPE@XY"]) as sc, \arcpy.da.InsertCursor(rounded_points, ["SHAPE@XY"]) as ic:for row in sc:x, y = row[0]ic.insertRow([(round(x, 3), round(y, 3))])# ===== 阶段3:批量拆分线段 =====# 创建内存图层arcpy.MakeFeatureLayer_management(dissolve_path, "lines_lyr")arcpy.MakeFeatureLayer_management(rounded_points, "points_lyr")# 执行拆分操作split_result = arcpy.management.SplitLineAtPoint(in_features="lines_lyr",point_features="points_lyr",out_feature_class=os.path.join(output_folder, "JZX"),search_radius="0.001 Meters")
finally:# 清理临时数据for item in [dissolve_path, rounded_points]:if arcpy.Exists(item):arcpy.Delete_management(item)def calculate_direction(angle):"""根据方位角计算方向字典"""if 337.5 <= angle or angle < 22.5:return "东"elif 22.5 <= angle < 67.5:return "东南"elif 67.5 <= angle < 112.5:return "南"elif 112.5 <= angle < 157.5:return "西南"elif 157.5 <= angle < 202.5:return "西"elif 202.5 <= angle < 247.5:return "西北"elif 247.5 <= angle < 292.5:return "北"elif 292.5 <= angle < 337.5:return "东北"def get_angle(start_point, end_point):"""计算两点之间的方位角"""dx = end_point.X - start_point.Xdy = end_point.Y - start_point.Yangle = math.degrees(math.atan2(dy, dx))return (angle + 360) % 360# 创建字段
split_lines = os.path.join(output_folder, "JZX.shp")
for field in ["QZJDH", "ZJZDH", "JZXSM"]:if not arcpy.ListFields(split_lines, field):arcpy.AddField_management(split_lines, field, "TEXT", field_length=100)# 构建界址点索引
jzd_dict = defaultdict(dict)
with arcpy.da.SearchCursor(jzd_path, ["DKBM", "JZDH", "SHAPE@"]) as cursor:for row in cursor:key = (row[0], row[1])jzd_dict[key] = row[2].centroid # 获取质心坐标# ========== 处理界址线 ==========
with arcpy.da.UpdateCursor(split_lines, ["DKBM", "PLDWZJR", "SHAPE@", "QZJDH", "ZJZDH", "JZXSM"]) as cursor:for row in cursor:dkbm_line = row[0]pldwzjr = row[1] if row[1] else "无"geometry = row[2]# ===== 步骤1:调整线段方向 =====# 获取首尾点坐标first_point = geometry.firstPointlast_point = geometry.lastPoint# 查找对应的界址点号found_start = Nonefound_end = None# 建立一个DKBM与ZJDH的键值对found_sartdkbm = Nonefound_enddkbm = Nonefor (dkbm_part, jzdh), point in jzd_dict.items():set1 = set(dkbm_line.split("/"))set2 = set(dkbm_part.split("/"))if not set1.isdisjoint(set2):if (abs(point.X - first_point.X) < 0.001 andabs(point.Y - first_point.Y) < 0.001):found_start = jzdhfound_sartdkbm=dkbm_partif (abs(point.X - last_point.X) < 0.001 andabs(point.Y - last_point.Y) < 0.001):found_end = jzdhfound_enddkbm=dkbm_partline_dkbm=dkbm_line.split("/")list_qjzdh=[]list_zjzdh = []for i in line_dkbm:list_jzdh1=found_start.split("/")list_dkbm1=found_sartdkbm.split("/")for j in range(len(list_dkbm1)):if i==list_dkbm1[j]:list_qjzdh.append(int(list_jzdh1[j]))list_jzdh2 = found_end.split("/")list_dkbm2 = found_enddkbm.split("/")for j in range(len(list_dkbm2)):if i == list_dkbm2[j]:list_zjzdh.append(int(list_jzdh2[j]))def reverse_polyline(geom):array = arcpy.Array()part = geom.getPart(0) # 获取线段的点集合reversed_part = [pnt for pnt in part][::-1] # 反转坐标点顺序for pnt in reversed_part:array.add(pnt)return arcpy.Polyline(array) # 重建反转后的线段# 判断是否需要反转if found_start and found_end and sum(list_qjzdh) > sum(list_zjzdh):geometry = reverse_polyline(geometry)# ===== 步骤2:生成起止点号 =====# 生成字段值str_qjzdh=''if len(list_qjzdh)==1:str_qjzdh =str_qjzdh + 'J'+str(list_qjzdh[0])else:str_qjzdh = str_qjzdh + 'J' + str(list_qjzdh[0])+u'/J'+str(list_qjzdh[1])str_zjzdh=''if len(list_zjzdh)==1:str_zjzdh =str_zjzdh + 'J'+str(list_zjzdh[0])else:str_zjzdh = str_zjzdh + 'J' + str(list_zjzdh[0])+u'/J'+str(list_zjzdh[1])row[3] =str_qjzdhrow[4] = str_zjzdh# ===== 步骤3:生成描述字段 =====# 计算长度length = round(geometry.length, 2)# 计算方向start_pt = geometry.firstPointend_pt = geometry.lastPointangle = get_angle(start_pt, end_pt)direction = calculate_direction(angle)# 构建描述desc = "{}-{}:由{}界址点沿{}宗地分界线往{}方向长度{}m至{};".format(row[3].split("/")[0], row[4].split("/")[0], row[3].split("/")[0],pldwzjr if pldwzjr != "无" else "",direction,length,row[4].split("/")[0])row[5] = desccursor.updateRow(row)print(u"处理完成!")
相关文章:
【ArcGIS技巧】根据地块、界址点图层生成界址线
"农经权二轮延包我已经写的差不多了,需要的一些生成四至、分割地块的功能也分享了替代的插件。前面刚分享完界址点的生成,今天分享界址线的生成,有需要的自取,至此,基本可以用这些功能完成出成果工作。" 1、…...
PC:使用WinSCP密钥文件连接sftp服务器
1. 打开winscp工具,点击“标签页”->“新标签页” 2. 点击“高级"->“高级” 3. 点击"验证"->“选择密钥文件” 选择ppk文件,如果没有ppk文件选择pem文件,会自动生成ppk文件 点击确定 4. 输入要连接到的sftp服务器的…...
RedHat7 如何更换yum镜像源
RedHat7如何更换yum镜像源? # 删除系统自带 yum rpm -qa|grep -e yum -e python-urlgrabber |xargs rpm -e --nodeps# 下载yum与wget的rpm软件包 curl -O http://mirrors.aliyun.com/centos/7/os/x86_64/Packages/yum-3.4.3-168.el7.centos.noarch.rpm curl -O ht…...
k8s 1.10.26 一次containerd失败引发kubectl不可用问题
k8s 1.10.26 一次containerd失败引发kubectl不可用问题 开机k8s 1.10.26时,报以下错误 [rootmaster ~]# kubectl get no E0515 08:03:00.914894 7993 memcache.go:265] couldnt get current server API group list: Get "https://192.168.80.50:6443/api?…...
Qt信号槽机制与UI设计完全指南:从基础原理到实战应用
目录 前言一、信号槽1.1 传参1.2 Qt信号与槽的对应关系1.2.1一对多关系1.2.2 多对一关系 二、Designer三、Layout 布局3.1 基础用法3.2 打破布局3.3 贴合窗口3.4 伸展器(Spacer)3.5 嵌套布局 四、ui指针五、QWidget六、QLabel 标签使用指南总结 前言 本…...
微信小程序van-dialog确认验证失败时阻止对话框的关闭
使用官方(Vant Weapp - 轻量、可靠的小程序 UI 组件库)的before-close: wxml: <van-dialog use-slot title"名称" show"{{ show }}" show-cancel-button bind:cancel"onClose" bind:confirm"getBackInfo"…...
嵌入式学习--江科大51单片机day7
我们在听课的过程中,可能对老师讲的有疑问,或者有些自己的理解,我们可以去问豆包,包括在写博客的时候我也是,不断去问豆包保证思考的正确性。(有人感觉豆包很low啊,其实这些基础性的东西豆包一般…...
spark和hadoop之间的区别和联系
Spark和Hadoop的对比 1. 架构层面 Hadoop: HDFS(分布式文件系统):Hadoop的核心组件之一,用于存储大规模数据。它将数据分散存储在多个节点上,通过冗余存储(默认三副本)来保证数据…...
antd mobile 点击 TabBar 切换页面
switchRoute 函数,navigate 点击的 path import { Button, TabBar } from "antd-mobile"; import { useEffect } from "react"; import { Outlet, useNavigate } from "react-router-dom"; import { useDispatch } from "react…...
20250515让飞凌的OK3588-C的核心板在Linux R4下适配以太网RTL8211F-CG为4线百兆时的接线图
20250515让飞凌的OK3588-C的核心板在Linux R4下适配以太网RTL8211F-CG为4线百兆时的接线图 2025/5/15 20:19 缘起:以前做的网线找不到了,那就再来一条吧。 引脚定义要从头来过?还好找到了一条。 开干! 万用表一对/点,几…...
大语言模型 07 - 从0开始训练GPT 0.25B参数量 - MiniMind 实机训练 预训练 监督微调
写在前面 GPT(Generative Pre-trained Transformer)是目前最广泛应用的大语言模型架构之一,其强大的自然语言理解与生成能力背后,是一个庞大而精细的训练流程。本文将从宏观到微观,系统讲解GPT的训练过程,…...
【学习心得】WSL2安装Ubuntu22.04
为了使用Docker desktop,所以我的win10需要安装一下wsl并且下载一个Ubuntu。默认Windows10/11是自带wsl的,你在进行下面操作的时候可以升级一下wsl --update 1、管理员身份打开cmd,输入命令查询所有可以下载的Linux版本 # 查看有哪些 Linux 发…...
人工智能、深度学习、机器学习的联系与区别
定义 人工智能(AI - Artificial Intelligence) :是研究、开发用于模拟、延伸和扩展人的智能的理论、方法、技术及应用系统的一门新的技术科学。它旨在让计算机能够像人类一样思考、学习和决策,涉及到诸如计算机视觉、自然语言处理…...
基于互联网和LabVIEW的多通道数据采集系统仿真设计
标题:基于互联网和LabVIEW的多通道数据采集系统仿真设计 内容:1.摘要 在当今科技飞速发展的背景下,多通道数据采集在众多领域有着广泛需求。本研究的目的是设计一个基于互联网和LabVIEW的多通道数据采集系统仿真方案。采用互联网技术实现数据的远程传输与共享&…...
【Android】Android 实现一个依赖注入的注解
Android 实现一个依赖注入的注解 🎯 目标功能 自定义注解 Inject创建一个 Injector 类,用来扫描并注入对象支持 Activity 或其他类中的字段注入 🧩 步骤一:定义注解 import java.lang.annotation.ElementType; import java.lan…...
【Ansible基础】Ansible 核心组件深度解析:控制节点、受管节点、Inventory与Playbook
目录 1 Ansible架构概述 2 控制节点(Control Node)详解 2.1 控制节点定义与功能 2.2 控制节点配置文件 3 受管节点(Managed Node)详解 3.1 受管节点特点 3.2 受管节点准备工作 3.3 连接方式对比 4 Invento…...
数据库--处理模型(Processing Model)(二)
执行查询的方法有很多,接下来将介绍以更高效和更有效率的方式执行分析工作负载(在OLAP系统中)的不同技术,包括以下内容: 执行并行性(Execution Parallelism)执行引擎(Execution Engines)执行操作符输出(Execution Operator Output)中间数据表示(Intermediate Data …...
机器学习 day03
文章目录 前言一、特征降维1.特征选择2.主成分分析(PCA) 二、KNN算法三、模型的保存与加载 前言 通过今天的学习,我掌握了机器学习中的特征降维的概念以及用法,KNN算法的基本原理及用法,模型的保存和加载 一、特征降维…...
鸿蒙OSUniApp 制作简洁高效的标签云组件#三方框架 #Uniapp
UniApp 制作简洁高效的标签云组件 在移动端应用中,标签云(Tag Cloud)是一种常见的UI组件,它以视觉化的方式展示关键词或分类,帮助用户快速浏览和选择感兴趣的内容。本文将详细讲解如何在UniApp框架中实现一个简洁高效的…...
【测试】用例篇
目录 1、如何编写测试用例: 1.1、设计测试用例时:正向思维逆向思维发散思维 2.2、万能公式 2、设计测试用例的方法 2.1、基于需求设计方法 1)等价类: 2)边界类 3)场景法 4)正交表法 5)…...
力扣-46.全排列
题目描述 给定一个不含重复数字的数组 nums ,返回其 所有可能的全排列 。你可以 按任意顺序 返回答案。 class Solution {List<List<Integer>> res new ArrayList<>();List<Integer> path new ArrayList<>();void backtracking(i…...
【氮化镓】HfO2钝化优化GaN 器件性能
2025年,南洋理工大学的Pradip Dalapati等人在《Applied Surface Science》期刊发表了题为《Role of ex-situ HfO2 passivation to improve device performance and suppress X-ray-induced degradation characteristics of in-situ Si3N4/AlN/GaN MIS-HEMTs》的文章。该研究基…...
STL?list!!!
一、引言 之前我们一起完成了STL库中的vector,本期我们将一起完成list这一容器,在本期学习中,我们会更加加深对于模板的认识,让我们更加能感受到模板的魅力! 二、list的介绍与相关接口 list是STL库中提供的一个链表容…...
2025.05.14华为机考笔试题-第一题-100分
📌 点击直达笔试专栏 👉《大厂笔试突围》 💻 春秋招笔试突围在线OJ 👉 笔试突围OJ 01. 优先级任务调度系统 问题描述 LYA公司的开发团队正在设计一个智能任务调度系统。该系统需要根据任务优先级动态调整执行顺序,以提高团队工作效率。系统需要支持以下三种操作:…...
紫外相机工作原理及可应用范围
紫外相机是一种利用紫外线(UV)波段进行成像的设备,紫外线可用于机器视觉应用中,以检测使用可见光无法检测到的特征,工业上使用最常见的紫外波长是365nm和395nm。紫外相机通常用于高分辨率视频显微镜、电晕检测、半导体…...
海外短剧H5/App开源系统搭建指南:多语言+国际支付+极速部署
在全球短视频与短剧内容消费热潮下,搭建一个支持多语言、集成国际支付且能快速部署的海外短剧平台,已成为内容创作者和运营者的核心需求。本文将结合行业前沿技术与开源方案,提供一套完整的系统搭建指南,助您高效实现全球化布局 …...
AWS EC2 微服务 金丝雀发布(Canary Release)方案
为什么需要实现金丝雀发布? 在当前项目的工程实践中, 已经有了充分的单元测试, 预发布环境测试, 但是还是会在线上环境出现非预期的情况, 导致线上事故, 因此, 为了提升服务质量, 需要线上能够有一个预验证的机制. 如何实现金丝雀发布? 使用AWS code deploy方案 AWS code…...
2025年5月华为H12-821新增题库带解析
IS-IS核心知识 四台路由器运行IS-IS且已经建立邻接关系,区域号和路由器的等级如图中标记,下列说法中正确的有? R2和R3都会产生ATT置位的Level-1的LSPR1没有R4产生的LSP,因此R1只通过缺省路由和R4通信R2和R3都会产生ATT置位的Leve1-2的LSPR2和…...
从单体架构到微服务:架构演进之路
引言:当“大货车”遇上“集装箱运输” 在软件开发领域,单体架构曾像一辆载满货物的大货车,将所有功能打包在一个应用中。但随着业务复杂度飙升,这辆“大货车”逐渐陷入泥潭:启动慢如蜗牛、故障波及全局、升级如履薄冰……...
从 Excel 到 Data.olllo:数据分析师的提效之路
背景:Excel 的能力边界 对许多数据分析师而言,Excel 是入门数据处理的第一工具。然而,随着业务数据量的增长,Excel 的一些固有限制逐渐显现: 操作容易出错,难以审计; 打开或操作百万行数据时&…...
Uniapp开发鸿蒙购物项目教程之样式选择器
大家好,今天依然为大家带来鸿蒙跨平台开发教程的分享,我们本系列的教程最终要做一个购物应用,通过这个项目为大家分享uniapp开发鸿蒙应用从配置开发环境到应用打包上架的完成过程。 昨天的文章实现了应用首页的轮播图,其中涉及到…...
AI全域智能监控系统重构商业清洁管理范式——从被动响应到主动预防的监控效能革命
一、四维立体监控网络技术架构 1. 人员行为监控 - 融合人脸识别、骨骼追踪与RFID工牌技术,身份识别准确率99.97% - 支持15米超距夜间红外监控(精度0.01lux) 2. 作业过程监控 - UWB厘米级定位技术(误差<0.3米&…...
协作赋能-1-制造业生产流程重构
制造业生产流程重构——从“信息孤岛”到“全链协同” 在制造业的数字化转型浪潮中,一个看似矛盾的现象正在蔓延:企业部署了ERP、MES、PLM等管理系统,却仍未摆脱“纸质工单满天飞、跨部门扯皮不断”的困境。以汽车制造业为例,其…...
游戏行业DDoS攻击类型及防御分析
游戏行业作为DDoS攻击的高发领域,攻击类型复杂多样,结合多个来源的信息,以下是其主要攻击类型及特征分析: 1. 传统流量型DDoS攻击 UDP洪水攻击:通过大量UDP报文淹没服务器端口,消耗带宽资源,导…...
嵌入式学习的第二十一天-数据结构-双向链表
一、双向链表 1.定义 双向链表是在单链表的每个结点中,再设置一个指向其钱去节点的指针域。 typedef struct DulNode {ElemType date;struct DulNode *pri;//直接前驱指针sturct DulNode *next;//直接后继指针 }DulNode,*DuLinkList;2.双向链表的创建 …...
Python爬虫第21节- 基础图形验证码识别实战
目录 前言 一、学习目标 二、环境准备 2.1 安装依赖 2.2 验证安装 三、获取验证码图片 3.1 常见获取方式 3.2 图片格式要求 四、基础识别流程 4.1 基础流程 4.2 常见问题及解决方案 五、 图像预处理提升识别率 5.1 灰度化 5.2 二值化 5.3 自定义阈值二值化 5.4…...
【React全栈进阶】从组件设计到性能优化实战指南
目录 🌟 前言🏗️ 技术背景与价值🩹 当前技术痛点🛠️ 解决方案概述👥 目标读者说明 🧠 一、技术原理剖析📊 核心概念图解💡 核心作用讲解🔧 关键技术模块说明⚖️ 技术选…...
基于EFISH-SCB-RK3576/SAIL-RK3576的消防机器人控制器技术方案
(国产化替代J1900的应急救援智能化解决方案) 一、硬件架构设计 极端环境防护系统 防爆耐高温设计: 采用陶瓷纤维复合装甲(耐温1200℃持续1小时),通过GB 26784-2023消防设备防爆认证IP68防护等级…...
插件双更新:LeetCode 刷题支持正式上线,JetBrains IDE 插件持续升级!
为了让更多开发者在真实开发与算法练习中体验 MoonBit 的高效表达与编译性能,MoonBit 语言现已实现对 JetBrains 开发环境与 LeetCode 答题平台的全面支持! 无论你是习惯用 IDE 编写项目的开发者,还是希望通过 LeetCode 刷题提升算法能力的程…...
编译OpenSSL时报错,Can‘t locate IPC/Cmd.pm in @INC perl环境
Unix / Linux / macOS $ ./Configure $ make $ make test1、make Can‘t locate IPC/Cmd.pm in INC [ Downloads ] - /source/index.html https://www.openssl.org/source/ yum -y install perl-IPC-Cmd 2.make test Can’t locate Test/More.pm in INC perl环境 yum -…...
新型智慧园区技术架构深度解析:数字孪生与零碳科技的融合实践
🏭在杭州亚运村零碳园区,光伏板与氢燃料大巴构成的能源网络,正通过数字孪生技术实现智能调度。这不仅是格力电器与龙源电力在新能源领域的创新实践,更是智慧园区4.0时代的标杆案例。当AI算法开始接管能源调度,当BIM建模…...
2025全网首发:ComfyUI整合GPT-Image-1完全指南 - 8步实现AI图像创作革命
ComfyUI整合GPT-Image-1完全指南:8步实现AI图像创作革命【2025最新】 OpenAI最新发布的GPT-Image-1模型(也就是ChatGPT-4o背后的图像生成技术)已经通过API开放使用,而令人惊喜的是,ComfyUI已经第一时间提供了完整支持&…...
AWS Elastic Beanstalk控制台部署Spring极简工程
问题 上次通过EB CLI工具没有成功在AWS中国云部署成功,这次通过EB web控制台来部署。 步骤 接着上次部署失败的Spring工程:AWS Elastic Beanstalk部署极简Spring工程(EB CLI失败版),准备好jar文件。 创建ec2私钥文…...
力扣-236.二叉树的最近公共祖先
题目描述 给定一个二叉树, 找到该树中两个指定节点的最近公共祖先。 百度百科中最近公共祖先的定义为:“对于有根树 T 的两个节点 p、q,最近公共祖先表示为一个节点 x,满足 x 是 p、q 的祖先且 x 的深度尽可能大(一个节点也可以…...
LeetCode 3337.字符串转换后的长度 II:矩阵快速幂(也没有想象中的那么高级啦)
【LetMeFly】3337.字符串转换后的长度 II:矩阵快速幂(也没有想象中的那么高级啦) 力扣题目链接:https://leetcode.cn/problems/total-characters-in-string-after-transformations-ii/ 给你一个由小写英文字母组成的字符串 s,一个整数 t 表…...
【iOS】源码阅读(四)——isa与类关联的原理
文章目录 前言OC对象本质探索clang探索对象本质objc_setProperty源码探索 cls与类的关联原理为什么说bits与cls为互斥关系isa的类型isa_t原理探索isa与类的关联 总结 前言 本篇文章主要是笔者在学习和理解类与isa的关联关系时所写的笔记。 OC对象本质探索 在学习和理解类与isa…...
elementUI 循环出来的表单,怎么做表单校验?
数据结构如下: diversionParamList: [ { length: null, positionNumber: null, value: null, } ] 思路:可根据 index 动态绑定 :props 属性值,校验规则写在:rules <div class"config-item" v-for"(item, index) in form.…...
蓝桥杯11届国B 约数
题目描述 定义阶乘 n!123⋅⋅⋅n。 请问 100! (100 的阶乘)有多少个正约数 100! 是所有从 1 到 100 的数的乘积,因此: 质数 j 在 100! 中的总指数 质数 j 在 1 中的指数 质数 j 在 2 中的指数 ... 质数 j 在 100 中的指数 …...
【iOS】alloc的实际流程
目录 前言 为什么不按源码流程调用? alloc的调用流程 前言 在之前的博客中我们有学习到过alloc的底层原理,沿着源码一步步找到了alloc的调用链——alloc—>_objc_rootAlloc—>callAlloc—>_objc_rootAllocWithZone—>_class_createInstan…...
Maven clean 提示文件 java.io.IOException
Maven clean 提示文件 java.io.IOException 问题背景问题分析&处理问题总结 问题背景 今天在一个功能开发结束之后,准备通过Maven实现打包操作,然后打包完成后部署到测试环境进行测试。在IDEA开发工具,点击 clean 时提示 Failed to dele…...