繁体   English   中英

ValueError:小端编译器不支持大端缓冲区

[英]ValueError: Big-endian buffer not supported on little-endian compiler

我正在使用 PVlib 对光伏阵列建模,有时当我尝试访问天气预报数据时,我收到以下错误:

ValueError: Big-endian buffer not supported on little-endian compiler

我不确定为什么它只是有时发生,而不是每次运行代码时发生。 下面是我正在运行的代码,最后一行是导致错误的代码。 任何解决此问题的帮助将不胜感激,谢谢!!

# built-in python modules
import datetime
import inspect
import os
import pytz

# scientific python add-ons
import numpy as np
import pandas as pd

# plotting
# first line makes the plots appear in the notebook
%matplotlib inline 
import matplotlib.pyplot as plt
import matplotlib as mpl

#import the pvlib library
from pvlib import solarposition,irradiance,atmosphere,pvsystem
from pvlib.forecast import GFS
from pvlib.modelchain import ModelChain

pd.set_option('display.max_rows', 500)

latitude, longitude, tz = 21.300268, -157.80723, 'Pacific/Honolulu' 

# specify time range.
# start = pd.Timestamp(datetime.date.today(), tz=tz)
pacific = pytz.timezone('Etc/GMT+10')
# print(pacific)
# datetime.datetime(year, month, day, hour, minute, second, microsecond, tzinfo)
start2 = pd.Timestamp(datetime.datetime(2020, 2, 10, 13, 0, 0, 0, pacific))
# print(start)
# print(start2)
# print(datetime.date.today())

end = start2 + pd.Timedelta(days=1.5)

# Define forecast model
fm = GFS()

# get data from location specified above
forecast_data = fm.get_processed_data(latitude, longitude, start2, end)
# print(forecast_data)

我想我现在有一个解决方案。 出于某种原因,来自这些 UNIDATA DCSS 查询的数据偶尔会返回大端字节。 这与此处讨论的 Pandas Dataframe 或 Series 对象不兼容。 我在 PVLIB 中找到了从 NetCDF4 获取数据并创建 Pandas Dataframe 的函数。 往里pvlib然后forecast.py和函数被调用_netcdf2pandas 我将复制下面的源代码:

data_dict = {}
for key, data in netcdf_data.variables.items():
    # if accounts for possibility of extra variable returned
    if key not in query_variables:
        continue
    squeezed = data[:].squeeze()
    if squeezed.ndim == 1:
        data_dict[key] = squeezed
    elif squeezed.ndim == 2:
        for num, data_level in enumerate(squeezed.T):
            data_dict[key + '_' + str(num)] = data_level
    else:
        raise ValueError('cannot parse ndim > 2')

data = pd.DataFrame(data_dict, index=self.time)

目标是将 NetCDF4 数据压缩到单个 Pandas 系列中,将每个系列保存到字典中,然后将所有这些数据导入到数据框并返回。 我所做的只是在此处添加一个检查,以确定压缩序列是否为 Big-Endian 并将其转换为 Little-Endian。 我修改后的代码如下:

for key, data in netcdf_data.variables.items():
    # if accounts for possibility of extra variable returned
    if key not in query_variables:
        continue
    squeezed = data[:].squeeze()

    # If the data is big endian, swap the byte order to make it little endian
    if squeezed.dtype.byteorder == '>':
        squeezed = squeezed.byteswap().newbyteorder()

    if squeezed.ndim == 1:
        data_dict[key] = squeezed
    elif squeezed.ndim == 2:
        for num, data_level in enumerate(squeezed.T):
            data_dict[key + '_' + str(num)] = data_level
    else:
        raise ValueError('cannot parse ndim > 2')

data = pd.DataFrame(data_dict, index=self.time)

我使用这个 Stack Overflow 答案来确定每个系列的字节序。 SciPy 文档给了我一些关于这些字节顺序可能是什么类型的数据的线索。

这是我对 pv-lib 的拉取请求,它为我解决了问题 我希望这有帮助。 我仍然不知道为什么问题不一致。 大约 95% 的时间,我尝试get_processed_data会失败。 当它起作用时,我以为我找到了修复程序,然后 Pandas 会抛出字节序错误。 在对 pv-lib 实施修复后,我不再有来自 Pandas 的关于大端或小端的错误。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM