matlab - 'cdfread' 不读取 .cdf 文件 Matlab
问题描述
我无法使用 Matlabcdfread
函数读取“.cdf”文件。我也试过netcdf
文件'mvn_lpw_l2_lpnt_20180814_v03_r02.cdf'可在此处获得:
我正在使用 Matlab R2015a(8.5 版)。
请提供任何帮助。
解决方案
要从 NASA Space Physics Data Facility (SPDF) 读取数据,建议您使用 SPDF 的 CDF 处理库。这个版本的库是免费提供的,可以直接从 SPDF下载。安装说明相当简单,几乎没有什么可以添加的。
MATLAB 附带的 cdflib 版本不支持 MAVEN 文件中使用的某些功能。使用在 MATLAB 2017a (9.2.0) 上运行的 MATLAB 提供的 CDFLIB,您将获得
>> cdfinfo('mvn_lpw_l2_lpnt_20180814_v03_r02.cdf')
Error using cdflibmex
33 is not a recognized DATATYPE mode.
[... stack trace ...]
>> data = cdfread('mvn_lpw_l2_lpnt_20180814_v03_r02.cdf')
Error using cdflibmex
33 is not a recognized DATATYPE mode.
[... stack trace ...]
使用 CDF 例程的 SPDF 版本,您将获得正确的输出:
>> mvninfo = spdfcdfinfo('mvn_lpw_l2_lpnt_20180814_v03_r02.cdf')
mvninfo =
struct with fields:
Filename: 'mvn_lpw_l2_lpnt_20180814_v03_r02.cdf'
FileModDate: '01-Jan-2019 03:18:45'
FileSize: 2579209
Format: 'CDF'
FormatVersion: '3.6.3'
FileSettings: [1×1 struct]
Subfiles: {}
Variables: {7×12 cell}
GlobalAttributes: [1×1 struct]
VariableAttributes: [1×1 struct]
LibVersion: '3.7.0'
PatchVersion: '3.7.0.0'
并将spdfcdfread
数据作为 MATLAB 数组返回
>> mvndata = spdfcdfread('mvn_lpw_l2_lpnt_20180814_v03_r02.cdf')
mvndata =
1×7 cell array
Columns 1 through 3
[17532×10 single] [17532×1 double] [17532×1 double]
Columns 4 through 6
[17532×10 single] [17532×10 single] [17532×1 single]
Column 7
[17532×1 single]
MATLAB CDFLIB 函数中错误的一个可能原因来自用于epoch
MAVEN 文件中的变量的 TT2000 数据类型。
data epoch time_unix ddata_lo ddata_up flag info
________ ________ _________ ________ ________ ________ ________
'single' 'tt2000' 'double' 'single' 'single' 'single' 'single'
推荐阅读
- javascript - 转到 toString 然后返回时的正则表达式意外行为
- php - 无法在 laravel 5.5 控制器中检索 file_get_contents('php://input')
- apache-spark - 使用 spark 更新 ElasticSearch 中的嵌套对象
- java - 实现一个 kotlin 泛型函数,从复杂的 java 对象中检索特定字段
- python - python和yaml提取某些yaml字段的值
- c# - System.AccessViolationException 从 C# 调用 c++ 函数
- react-native - 如何从身份证和护照中扫描和提取数据
- c++ - C++ 我应该如何解释函数参数 long(*pPointer)(OtherClass *const, long)?
- mysql - 如何在 Pentaho Server 中创建 MySQL 数据连接
- mysql - 如何从 MYSQL 的特定用户组中获得最低价格