如何在python或java中将geotiff转换为jpg?

송준석*_*송준석 4 python java image gdal geotiff

我有一个带有 3bands 的 geotiff 图像。

band1,2 是实际图像值,band3 是实例角度值。

band1,2 是 float32 数据类型

下面的代码是我之前尝试过的。

但它不起作用。

我认为波段数据的范围太大,所以没有

from osgeo import gdal, osr, ogr
from PIL import Image
import numpy as np


ds = gdal.Open('image path', gdal.GA_ReadOnly)
rb = ds.GetRasterBand(1)
test = rb.ReadAsArray()
rb2 = ds.GetRasterBand(2)
test2 = rb2.ReadAsArray()
rb3 = ds.GetRasterBand(3)
test3 = rb3.ReadAsArray()
slice56 = test2
formatted = (slice56 * 255 / np.max(slice56)).astype('uint8')
img = Image.fromarray(formatted)
img.save('save image path')
Run Code Online (Sandbox Code Playgroud)

我怎么解决这个问题??

the*_*eff 10

您可以gdal.Translate为此使用。

你可以在这里阅读文档

from osgeo import gdal
    
options_list = [
    '-ot Byte',
    '-of JPEG',
    '-b 1',
    '-scale'
]           

options_string = " ".join(options_list)
    
gdal.Translate(
    'save_image_path.jpg',
    'image_path.tif',
    options=options_string
)
Run Code Online (Sandbox Code Playgroud)

上面的代码只是创建了一个 jpg 文件,带 1 缩放到字节范围。您可以通过添加'-b 2'等方式添加更多波段。另请注意, scale 会自动将整个范围包装到字节范围内。如果您喜欢其他东西,您可以使用'-scale min_val max_val'它来指定您喜欢的范围,因为通常您不需要可用的最低或最高值。