Expand description
A Rust library for reading LabVIEW TDMS files.
tdms
is a LabVIEW TDMS file parser library written in Rust. This is meant to be a general purpose library for reading and performing any calculation work on data contained in those files.
Note: This library is a work in progress. While I do not expect the current function signatures and library structure to change, you could experience difficulties due to early adoption.
Current Features
- Read both standard and big endian encoded files
- Read files with DAQmx data and data indices
- Read all segments in file, along with their groups and channels (per segment only)
- Read all raw data contained in all segments in file (as a
Vec<u8>
only at the present time) - Logging using the
log
api - users of the library must choose and initialize the implementation, such asenv-logger
Planned Features
- Iterators for each channel type, return native Rust values from encoded data channels
- DAQmx data channel iterator support
- Searching on string channels
Usage
extern crate tdms;
use std::path::Path;
use tdms::data_type::TdmsDataType;
use tdms::TDMSFile;
fn main() {
// open and parse the TDMS file, passing in metadata false will mean the entire file is
// read into memory, not just the metadata
let file = match TDMSFile::from_path(Path::new("data/standard.tdms")) {
Ok(f) => f,
Err(e) => panic!("{:?}", e),
};
// fetch groups
let groups = file.groups();
for group in groups {
// fetch an IndexSet of the group's channels
let channels = file.channels(&group);
let mut i = 0;
for (_, channel) in channels {
// once you know the channel's full path (group + channel) you can ask for the full
// channel object. In order to fetch a channel you must call the proper channel func
// depending on your data type. Currently this feature is unimplemented but the method
// of calling this is set down for future changes
let full_channel = match channel.data_type {
// the returned full channel is an iterator over raw data
TdmsDataType::DoubleFloat(_) => file.channel_data_double_float(channel),
_ => {
panic!("{}", "channel for data type unimplemented")
}
};
let mut full_channel_iterator = match full_channel {
Ok(i) => i,
Err(e) => {
panic!("{:?}", e)
}
};
println!("{:?}", full_channel_iterator.count());
i += 1;
}
}
}
More information about the TDMS file format can be found here: https://www.ni.com/en-us/support/documentation/supplemental/07/tdms-file-format-internal-structure.html
Contributing
Pull requests are welcome. For major changes, please open an issue first to discuss what you would like to change.
Please make sure to update tests as appropriate.
License
Re-exports
pub use error::TdmsError;
Modules
Macros
Structs
TDDMSFile
represents all segments
of a TDMS file in the order in which they were read.