hdf5/HDF5Examples/CXX/TUTR/h5tutr_rdwt.cpp

71 lines
2.3 KiB
C++
Raw Normal View History

/* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *
2019-09-19 01:11:12 +08:00
* Copyright by The HDF Group. *
* All rights reserved. *
* *
* This file is part of HDF5. The full HDF5 copyright notice, including *
* terms governing use, modification, and redistribution, is contained in *
* the COPYING file, which can be found at the root of the source code *
* distribution tree, or in https://www.hdfgroup.org/licenses. *
* If you do not have access to either file, you may request a copy from *
* help@hdfgroup.org. *
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
/*
* This example illustrates how to write to and read from an existing
* dataset. It is used in the HDF5 Tutorial.
*/
#include <iostream>
#include <string>
#include "H5Cpp.h"
using namespace H5;
2020-09-30 22:27:10 +08:00
const H5std_string FILE_NAME("h5tutr_dset.h5");
const H5std_string DATASET_NAME("dset");
const int DIM0 = 4; // dataset dimensions
const int DIM1 = 6;
2020-09-30 22:27:10 +08:00
int
main(void)
{
2020-04-21 07:12:00 +08:00
// Data initialization.
2020-04-21 07:12:00 +08:00
int i, j;
2020-09-30 22:27:10 +08:00
int data[DIM0][DIM1]; // buffer for data to write
for (j = 0; j < DIM0; j++)
2019-09-19 01:11:12 +08:00
for (i = 0; i < DIM1; i++)
2020-09-30 22:27:10 +08:00
data[j][i] = i * 6 + j + 1;
// Try block to detect exceptions raised by any of the calls inside it
2020-09-30 22:27:10 +08:00
try {
2019-09-19 01:11:12 +08:00
// Turn off the auto-printing when failure occurs so that we can
// handle the errors appropriately
Exception::dontPrint();
2019-09-19 01:11:12 +08:00
// Open an existing file and dataset.
2020-09-30 22:27:10 +08:00
H5File file(FILE_NAME, H5F_ACC_RDWR);
2019-09-19 01:11:12 +08:00
DataSet dataset = file.openDataSet(DATASET_NAME);
2019-09-19 01:11:12 +08:00
// Write the data to the dataset using default memory space, file
// space, and transfer properties.
dataset.write(data, PredType::NATIVE_INT);
2020-09-30 22:27:10 +08:00
} // end of try block
// catch failure caused by the H5File operations
2020-09-30 22:27:10 +08:00
catch (FileIException error) {
2019-09-19 01:11:12 +08:00
error.printErrorStack();
return -1;
}
// catch failure caused by the DataSet operations
2020-09-30 22:27:10 +08:00
catch (DataSetIException error) {
2019-09-19 01:11:12 +08:00
error.printErrorStack();
return -1;
}
2020-09-30 22:27:10 +08:00
return 0; // successfully terminated
}