19 February 2021
- Extended support for additional date/time formats (#86)
- Fixed incorrect date calculation for years > 4000 (#81)
- Fixed infinite loop on fuzzed file bug (#58)
17 December 2020
- Integrated with github actions (#66)
- Fixed format and precision reading for 64 bit files (#54)
- Fixed encoding issues in compressed files (#55)
- Code improvements, switching to assertj from fest-assert (#71, #72)
- Fixed offset calculation for deleted records (#77)
19 August 2020
- Added support for deleted rows (#38)
- Added more various time formatters and moved them to interface (#48)
- Made SASFileParser API public (#51)
- Added sanity check to page length (#60)
25 March 2019
- Added ability to override file encoding (#30)
- Added ability to get file label (#34)
- Decimal separator used to convert percentage elements was fixed (#35)
28 September 2018
- Fixed processing of columns formats and labels
- Fixed formatting of percentage values (#28)
26 April 2018
- Added ability to read precision information (#22)
- Exposed formatting API for reuse (#24)
- Added ability to read only specified columns to improve performance
- Fixed bug #26
12 January 2018
- Changed license to ALv2
24 March 2017
- Fixed handling of non-seekable binary channel.
- Added ability to set locale used for dates in csv file.
14 March 2017
- Added handling of many additional date and datetime format patterns.
10 March 2017
- Fixed handling of ISO8601 date format. Added new date pattern.
8 March 2017
- Added processing column names, formats and labels on page type 'amd'.
- Added handling of ISO8601 date format.
15 December 2016
- Added handling of empty or corrupted input stream.
24 October 2016
- Character encoding support added
- The subheaders signatures list updated
- Correct double-byte character encoding processing added
28 September 2016
- Double values processing corrected
28 March 2016
- Binary compression algorithm improved
- Char compression algorithm improved
- Correct processing of numbers larger than long
- Codestyle improvements
13 February 2016
- Data streams processing
- Converting SAS7BDAT datasets into CSV format
- Reading and converting metadata of SAS7BDAT datasets into CSV format
- Extracting all properties of SAS7BDAT files (creation date, modification date, etc.)
- Two ways to read the file data: in one go and row by row
Parso is a lightweight Java library that is designed to read SAS7BDAT datasets. The Parso interfaces are analogous to those that belong to libraries designed to read table-storing files, for example, CSVReader library. Despite its small size, the Parso library is the only full-featured open-source solution to process SAS7BDAT datasets (uncompressed, CHAR-compressed or BINARY-compressed). It is effective in processing clinical and statistical data, which is often stored in SAS7BDAT format. In addition, the Parso library allows users to convert data into CSV format.
- Stability: Successful processing in difficult cases (partially corrupt files, compression, etc.)
- High processing speed
- Easy-to-use API: You need a couple of lines of program code to convert your SAS7BDAT file into a model or CSV format
- JavaDoc for exposed API
- Algorithm descriptions enclosed
- Evolving project: EPAM continues to develop the library by adding new functionality
- On-going technical support: EPAM welcomes any comments and concerns about this product and will address them on a regular basis
- Possibility of integration with existing client projects
- Row-by-row reading of data allows you to optimally organize the storing of results
- Data streams processing: no need to save the files to process
- Converting SAS7BDAT datasets into CSV format
- Reading and converting metadata of SAS7BDAT datasets into CSV format
- Extracting all properties of SAS7BDAT files (creation date, modification date, etc.)
- Two ways to read the file data: in one go and row by row
EPAM has wide experience in integration services and will help you integrate Parso into your project. We will price those services based on your individual needs.
If you use Maven, add the following dependency into the pom.xml file:
<dependency>
    <groupId>com.epam</groupId>
    <artifactId>parso</artifactId>
    <version>2.0.14</version>
</dependency>Create a variable of the SasFileReader class and indicate your InputStream that contains the SAS7BDAT file as a parameter in the SasFileReader constructor:
com.epam.parso.SasFileReader sasFileReader = new SasFileReaderImpl(is);To get the properties of a SAS7BDAT file, use:
sasFileReader.getSasFileProperties();To get the description of the SAS7BDAT columns, use:
sasFileReader.getColumns();To get the data of the SAS7BDAT file, use:
sasFileReader.readAll(); //to read all rows at once
sasFileReader.readNext(); //to read rows one by oneTo convert the metadata of the file into CSV format, use:
Writer writer = new StringWriter();
CSVMetadataWriter csvMetadataWriter = new CSVMetadataWriterImpl(writer);
csvMetadataWriter.writeMetadata(sasFileReader.getColumns());To convert the data of the file into CSV format, use:
Writer writer = new StringWriter();
CSVDataWriter csvDataWriter = new CSVDataWriterImpl(writer);
csvDataWriter.writeColumnNames(sasFileReader.getColumns());To write all rows at once to the ‘writer’ variable:
csvDataWriter.writeRowsArray(sasFileReader.getColumns(), sasFileReader.readAll());To write rows one by one to the ‘writer’ variable:
csvDataWriter.writeRow(sasFileReader.getColumns(), sasFileReader.readNext());Copyright (C) 2015 EPAM
Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with the License. You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License.
If the ALv2-licensed Parso does not satisfy your needs, please contact us at [email protected] to discuss the possibility of a commercial license.
We hope that you decide to use the Parso library. At EPAM, we are available to help you use, integrate, and support Parso.