GDAl 之绘制栅格图像的大致直方图和精准直方图(8)

2024-03-26 23:28

本文主要是介绍GDAl 之绘制栅格图像的大致直方图和精准直方图(8),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

gdal的绘制大致直方图是仅查看概览或者抽样像素的一个子集

import os
from osgeo import gdal
import matplotlib.pyplot as plt
import numpy as np# Don't forget to change directory.
os.chdir(r'D:\DeskTop\learn_py_must\Learn_GDAL\osgeopy-data\osgeopy-data\Switzerland')ds = gdal.Open('dem_class2.tif')
band = ds.GetRasterBand(1)# 获取直方图数据
approximate_hist = band.GetHistogram()
exact_hist = band.GetHistogram(approx_ok=False)
for i in range(len(approximate_hist[1:6])):print(i)print(approximate_hist[i+1:i+2])print(exact_hist[i+1:i+2])x = np.arange(len((approximate_hist[1:6])))  # the label locations
width = 0.35  # the width of the barsfig, ax = plt.subplots()
rects1 = ax.bar(x - width/2-0.05, approximate_hist[1:6], width, label='Approximate Histogram')
rects2 = ax.bar(x + width/2+0.05, exact_hist[1:6], width, label='Exact Histogram')plt.xlabel('Pixel Value')
plt.ylabel('Frequency')
plt.title('Raster Histogram')
plt.legend()
plt.show()# # 将数据转换为列表以便绘制
# bins = [i+1 for i in range(len(approximate_hist[1:6]))]
# plt.figure(figsize=(10, 5))
# plt.bar(bins, approximate_hist[1:6], alpha=0.5, color='b', label='Approximate Histogram')
# plt.bar(bins, exact_hist[1:6], alpha=0.5, color='r', label='Exact Histogram')
#
# plt.xlabel('Pixel Value')
# plt.ylabel('Frequency')
# plt.title('Raster Histogram')
# plt.legend()
# plt.show()

结果

这篇关于GDAl 之绘制栅格图像的大致直方图和精准直方图(8)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/850210

相关文章

Python使用Matplotlib绘制3D曲面图详解

《Python使用Matplotlib绘制3D曲面图详解》:本文主要介绍Python使用Matplotlib绘制3D曲面图,在Python中,使用Matplotlib库绘制3D曲面图可以通过mpl... 目录准备工作绘制简单的 3D 曲面图绘制 3D 曲面图添加线框和透明度控制图形视角Matplotlib

一文教你Python如何快速精准抓取网页数据

《一文教你Python如何快速精准抓取网页数据》这篇文章主要为大家详细介绍了如何利用Python实现快速精准抓取网页数据,文中的示例代码简洁易懂,具有一定的借鉴价值,有需要的小伙伴可以了解下... 目录1. 准备工作2. 基础爬虫实现3. 高级功能扩展3.1 抓取文章详情3.2 保存数据到文件4. 完整示例

Python如何精准判断某个进程是否在运行

《Python如何精准判断某个进程是否在运行》这篇文章主要为大家详细介绍了Python如何精准判断某个进程是否在运行,本文为大家整理了3种方法并进行了对比,有需要的小伙伴可以跟随小编一起学习一下... 目录一、为什么需要判断进程是否存在二、方法1:用psutil库(推荐)三、方法2:用os.system调用

使用Python实现图像LBP特征提取的操作方法

《使用Python实现图像LBP特征提取的操作方法》LBP特征叫做局部二值模式,常用于纹理特征提取,并在纹理分类中具有较强的区分能力,本文给大家介绍了如何使用Python实现图像LBP特征提取的操作方... 目录一、LBP特征介绍二、LBP特征描述三、一些改进版本的LBP1.圆形LBP算子2.旋转不变的LB

Python中使用正则表达式精准匹配IP地址的案例

《Python中使用正则表达式精准匹配IP地址的案例》Python的正则表达式(re模块)是完成这个任务的利器,但你知道怎么写才能准确匹配各种合法的IP地址吗,今天我们就来详细探讨这个问题,感兴趣的朋... 目录为什么需要IP正则表达式?IP地址的基本结构基础正则表达式写法精确匹配0-255的数字验证IP地

OpenCV图像形态学的实现

《OpenCV图像形态学的实现》本文主要介绍了OpenCV图像形态学的实现,包括腐蚀、膨胀、开运算、闭运算、梯度运算、顶帽运算和黑帽运算,文中通过示例代码介绍的非常详细,需要的朋友们下面随着小编来一起... 目录一、图像形态学简介二、腐蚀(Erosion)1. 原理2. OpenCV 实现三、膨胀China编程(

使用Python开发一个图像标注与OCR识别工具

《使用Python开发一个图像标注与OCR识别工具》:本文主要介绍一个使用Python开发的工具,允许用户在图像上进行矩形标注,使用OCR对标注区域进行文本识别,并将结果保存为Excel文件,感兴... 目录项目简介1. 图像加载与显示2. 矩形标注3. OCR识别4. 标注的保存与加载5. 裁剪与重置图像

基于WinForm+Halcon实现图像缩放与交互功能

《基于WinForm+Halcon实现图像缩放与交互功能》本文主要讲述在WinForm中结合Halcon实现图像缩放、平移及实时显示灰度值等交互功能,包括初始化窗口的不同方式,以及通过特定事件添加相应... 目录前言初始化窗口添加图像缩放功能添加图像平移功能添加实时显示灰度值功能示例代码总结最后前言本文将

使用Python绘制蛇年春节祝福艺术图

《使用Python绘制蛇年春节祝福艺术图》:本文主要介绍如何使用Python的Matplotlib库绘制一幅富有创意的“蛇年有福”艺术图,这幅图结合了数字,蛇形,花朵等装饰,需要的可以参考下... 目录1. 绘图的基本概念2. 准备工作3. 实现代码解析3.1 设置绘图画布3.2 绘制数字“2025”3.3

使用Python绘制可爱的招财猫

《使用Python绘制可爱的招财猫》招财猫,也被称为“幸运猫”,是一种象征财富和好运的吉祥物,经常出现在亚洲文化的商店、餐厅和家庭中,今天,我将带你用Python和matplotlib库从零开始绘制一... 目录1. 为什么选择用 python 绘制?2. 绘图的基本概念3. 实现代码解析3.1 设置绘图画