【Python】矢量影像批量裁剪、合併

来源:https://www.cnblogs.com/123456feng/archive/2022/04/21/16171974.html
-Advertisement-
Play Games

前言 又到每日分享Python小技巧的時候了,今天給大家分享啥呢?大家要不要猜一猜,今天給大家分享矢量影像批量裁剪以及合併。 聽起來有點不懂,看完你就懂了,擴展知識。 矢量批量裁剪的代碼 在:chp10\python\矢量批量裁剪.tbx\矢量批量裁剪,可以直接運行,右鍵編輯查看代碼 代碼如下: P ...


前言

又到每日分享Python小技巧的時候了,今天給大家分享啥呢?大家要不要猜一猜,今天給大家分享矢量影像批量裁剪以及合併。

聽起來有點不懂,看完你就懂了,擴展知識。

在這裡插入圖片描述

矢量批量裁剪的代碼

在:chp10\python\矢量批量裁剪.tbx\矢量批量裁剪,可以直接運行,右鍵編輯查看代碼

代碼如下:

Python學習交流Q群:906715085###
#---------------------------------------------------------------------------
#1.py# Created on: 星期日 一月 10 2018 11:02:13 上午
#(generated by ArcGIS/ModelBuilder)
#Usage: 矢量圖批量切割, by 閆磊 4個參數
#原始數據 是圖層,可以多選
#切割工具是是接幅表 或者行政
#欄位是輸出mdb名稱
#輸出路徑
#---------------------------------------------------------------------------
#Create Geoprocessing Object
import  sys, os, string
import arcpyfrom arcpy import env
 defaultencoding = 'utf-8'if sys.getdefaultencoding() != defaultencoding:    
 reload(sys)   
  sys.setdefaultencoding(defaultencoding)
arcpy.env.overwriteOutput = True

inworkspace  = arcpy.GetParameterAsText(0)
arcpy.AddMessage("輸入數據="+inworkspace)
clipshp  = arcpy.GetParameterAsText(1)
arcpy.AddMessage("裁剪=clipshp"+clipshp)
fieldname= arcpy.GetParameterAsText(2)
arcpy.AddMessage("欄位=fieldname"+fieldname)
outworkspace  = arcpy.GetParameterAsText(3)
arcpy.AddMessage("輸出="+outworkspace)
mdbbool  = arcpy.GetParameterAsText(4)
arcpy.AddMessage("是否mdb="+mdbbool)
desc = arcpy.Describe(clipshp)
filepath=desc.CatalogPathp=filepath.find(".mdb")
ftype="String"for field in desc.fields:    
if field.Name ==fieldname:         
ftype=field.Type        
breakarcpy.AddMessage(u"預設地理資料庫:"+arcpy.env.scratchWorkspace)jfb_
Select=arcpy.env.scratchWorkspace+"\yl999"#不能c:\要c:\\或者 c:/
rows = arcpy.SearchCursor(clipshp)
#arcpy.AddMessage(u"5=執行到這裡")row = rows.next()#arcpy.AddMessage(u"6=執行到這裡")while row:    #arcpy.AddMessage(u"7=執行到這裡")    fieldvalue =""+ str(row.getValue(fieldname))    #arcpy.AddMessage(u"值fieldvalue="+fieldvalue)    if p>0: #mdb        Expression="["+fieldname +"]="    else:        Expression="\""+fieldname +"\"="    #arcpy.AddMessage(u"表達式Expression1="+Expression)       if ftype=="String":        
Expression=Expression+"'"+fieldvalue+"'"    
else:        
Expression=Expression+fieldvalue
    #arcpy.AddMessage(u"Expression2="+Expression)    
    arcpy.Select_analysis(clipshp, jfb_Select,Expression)   
     #arcpy.AddMessage(u"6=clipshp"+clipshp)    out_mdb=""    #arcpy.AddMessage("======================================================out_mdb"+out_mdb)    if mdbbool=="true":        
     out_mdb=outworkspace + "\\"+fieldvalue+".mdb"  #os.path.basename(dataset)         
     else:        
     out_mdb=outworkspace + "\\"+fieldvalue+".gdb"     
     arcpy.AddMessage(u"out_mdb"+out_mdb)    
     if not arcpy.Exists(out_mdb):        
     if mdbbool=="true":            arcpy.CreatePersonalGDB_management(os.path.dirname(out_mdb),os.path.basename(out_mdb))        
     else:            
     arcpy.CreateFileGDB_management(os.path.dirname(out_mdb),os.path.basename(out_mdb))
    mydatasets= string.split(inworkspace,";")

    for dataset in mydatasets:
        try:            
        mylayer=os.path.basename(dataset)            
        arcpy.AddMessage(u"clip:"+dataset+" to "+out_mdb+"\\"+ mylayer)            
        mylayer=mylayer.replace("(","")            
        mylayer=mylayer.replace(")","")            
        arcpy.Clip_analysis(dataset, jfb_Select,out_mdb+"\\"+ mylayer, "")        
        except Exception, ErrorDesc:                
        #If an error set output boolean parameter "Error" to True.           
         arcpy.AddError(str(ErrorDesc))    
         row = rows.next()if arcpy.Exists(jfb_Select):    
         arcpy.Delete_management(jfb_Select)

 

作用:使用一個矢量圖層批量裁剪多個矢量數據,欄位值是裁剪後資料庫名稱

在這裡插入圖片描述
在這裡插入圖片描述

批量裁剪參數設置界面

界面如下:

在這裡插入圖片描述

批量裁剪運行界面

是否mdb,勾上是mdb,不勾是gdb

在這裡插入圖片描述

◾矢量批量合併

在:chp10\python\批量合併.tbx\數據批量合併下,可以直接運行,右鍵編輯可以查看代碼

代碼如下:

import sys
##############################################
import arcpy
import string
try:    
workspace =arcpy.GetParameterAsText(0)  #'C:\Users\Administrator\Desktop\\cc'

    outdb =arcpy.GetParameterAsText(1)   #'C:\Users\Administrator\Desktop\\lutian.mdb'    
    arcpy.env.workspace = workspace    
    arcpy.AddMessage("outdb:"+outdb)    
    files = arcpy.ListWorkspaces("","")    
    for File in files:        
    arcpy.AddMessage("File:"+File)
        arcpy.env.workspace = outdb        
        fcs = arcpy.ListFeatureClasses()        
        for fc in fcs:            
        arcpy.AddMessage("fc:"+fc)            
        if arcpy.Exists(File + "\\" + fc):                
        arcpy.Append_management([ File + "\\" + fc], outdb + "\\" + fc,"NO_TEST","","")           
else:                
arcpy.AddMessage("not exists:"+File + "\\" + fc)
fcs = arcpy.ListTables()        
for fc in fcs:            
arcpy.AddMessage("fc:"+fc)            
if arcpy.Exists(File + "\\" + fc):                
arcpy.Append_management([File + "\\" + fc], outdb + "\\" + fc,"NO_TEST","","")            
else:                
arcpy.AddMessage("not exists:"+File + "\\" + fc)
dss = arcpy.ListDatasets()        
for ds in dss:            
arcpy.AddMessage("ds:"+ds)            
arcpy.env.workspace = outdb+"\\"+ds            
fcs1 = arcpy.ListFeatureClasses()            
for fc1 in fcs1:                
arcpy.AddMessage("fc1:"+fc1)                
if arcpy.Exists(File + "\\" + ds + "\\" + fc1):                    
arcpy.Append_management([File + "\\" + ds + "\\" + fc1], outdb + "\\" + ds + "\\" + fc1,"NO_TEST","","")                
else:                    
arcpy.AddMessage("not exists:"+File + "\\" + ds + "\\" + fc1)
except arcpy.ExecuteError:    
arcpy.AddWarning(arcpy.GetMessages())

 

參數如下,工作空間可以是地理資料庫(文件地理數據或者個人地理數據),也是可以一個文件夾,這裡建議是資料庫

在這裡插入圖片描述

批量合併參數設置界面

運行界面如下:

在這裡插入圖片描述

批量合併運行界面

◾影像批量裁剪

在:chp10\python\影像切割.tbx\影像切割,可以直接運行,右鍵編輯可以查看程式源代碼

源代碼如下:

Python學習交流Q群:906715085###
import sys, os, string,types
import arcpy
from arcpy import env

arcpy.env.overwriteOutput = True

oldraster  = arcpy.GetParameterAsText(0)
arcpy.AddMessage("1oldraster="+oldraster)
clipshp  = arcpy.GetParameterAsText(1)
arcpy.AddMessage("2clipshp="+clipshp)
fieldname= arcpy.GetParameterAsText(2)
arcpy.AddMessage("3fieldname="+fieldname)
outworkspace= arcpy.GetParameterAsText(3)
arcpy.AddMessage("4="+outworkspace)

arcpy.CheckOutExtension("spatial")
rows = arcpy.SearchCursor(clipshp)

jfb_Select=outworkspace+"/temp.shp" #不能c:\要c:\\或者c:/
for row in rows:

    try:        
    b=1       
     value=row.getValue(fieldname)        
     #gp.AddMessage("value="+value)        
     if (type(value) is types.IntType):           
      fieldvalue = str(value)            
      b=2        
      elif (type(value)  is types.StringType):   
      #是否string類型            
      fieldvalue = value        
      else:            
      fieldvalue = str(value)
        arcpy.AddMessage("fieldvalue="+fieldvalue)        
        if b==2:           
         Expression="\""+fieldname +"\" ="+fieldvalue+""       
          else:            
          Expression="\""+fieldname +"\" ='"+fieldvalue+"'"        arcpy.AddMessage("Expression="+Expression+",jfb_Select="+jfb_Select+",clipshp="+clipshp)        
          arcpy.Select_analysis(clipshp, jfb_Select, Expression)
        out_raster =outworkspace+"/"+fieldvalue+".tif"       
         arcpy.gp.ExtractByMask_sa(oldraster, jfb_Select, out_raster)   
          except Exception, ErrorDesc:       
           #If an error set output boolean parameter "Error" to True.       
            arcpy.AddError(str(ErrorDesc))if arcpy.Exists(jfb_Select):arcpy.Delete_management(jfb_Select)

 

作用:使用一個矢量數據,批量裁剪一個影像,矢量欄位值是裁剪後影像的數據名,格式為tif

參數:

在這裡插入圖片描述

影像批量裁剪參數設置界面

運行界面如下:

在這裡插入圖片描述

最後

這篇文章到這裡就結束了,再往下麵也沒有了,有沒有學會的小伙伴,記得點一個贊,沒有學會的也沒關係,可以評論或者私信

我。
在這裡插入圖片描述


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 《大話雲原生》系列文章期望用最通俗、簡單的語言說明雲原生生態系統內的組成及應用關係。此專欄的前兩篇文章 《【大話雲原生】煮餃子與docker、kubernetes之間的關係》 《【大話雲原生】負載均衡篇-小飯館的流量變大了》 歡迎品鑒! 一、服務接待中心與微服務網關 老婆最近快過生日了,我答應她去旅 ...
  • 文本文件可存儲的數據量多、每當需要分析或修改存儲在文件中的信息時,讀取文件都很有用,對數據分析應用程式 處理文件,讓程式能夠快速地分析大量的數據處理文件和保存數據可讓你的程式使用起來更容易 一、從文件中讀取數據1)讀取整個文件:先創建一個任意的文本文件,設置任意行,任意個數據,命名為data.txt ...
  • ##urllib的4個模板 1.request:最基本的http請求模塊,用來模擬發送請求,就像是在瀏覽器中輸入一個網址然後回車一樣,只需要傳入uel,timeout等參數就可以實現一個模擬請求。 主要功能:用於模擬發送請求打開和讀取URL。 2.error:異常處理模塊,如果出現請求錯誤,我們可以 ...
  • package com.oop;import java.io.IOException;//Demo1 類public class Demo1 { //main public static void main(String[] args) { } /* 修飾符 返回值類型 方法名(.....) { 方 ...
  • Write less to achieve more. 追求極簡是優秀程式員的特質之一,簡潔的代碼,不僅看起來更專業,可讀性更強,而且減少了出錯的幾率。 本文盤點一些Python中常用的一行(不限於一行)代碼,可直接用在日常編碼實踐中。 歡迎補充交流! 1. If-Else 三元操作符(ternar ...
  • 開頭 看電影還在花錢?啥年代了?居然還有看電影花錢的,今天就給你上一課,讓你看看看電影是不需要花錢的。說乾就乾,衝衝 沖,代碼與實現思路就放在下麵了。 實現目的與思路 目的: 實現對騰訊視頻目標url的解析與下載,由於第三方vip解析,只提供線上觀看,隱藏想實現對目標視頻的下載 思路: 首先拿到想要 ...
  • return語句用於退出函數,向調用方返回一個表達式。 return在不帶參數的情況下(或者沒有寫return語句),預設返回None。 None是一個特殊的值,它的數據類型是NoneType。NoneType是Python的特殊類型,它只有一個取值None。 它不支持任何運算也沒有任何內建方法,和 ...
  • DFA 演算法是通過提前構造出一個 樹狀查找結構,之後根據輸入在該樹狀結構中就可以進行非常高效的查找。 設我們有一個敏感詞庫,詞酷中的辭彙為:我愛你我愛他我愛她我愛你呀我愛他呀我愛她呀我愛她啊 那麼就可以構造出這樣的樹狀結構: 設玩家輸入的字元串為:白菊我愛你呀哈哈哈 我們遍歷玩家輸入的字元串 str ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...