61 breaking releases

new 0.62.0 May 8, 2024
0.60.0 Apr 22, 2024
0.58.0 Mar 28, 2024
0.52.0 Dec 14, 2023
0.2.1 Jul 30, 2021

#137 in Science

Download history 504/week @ 2024-01-22 408/week @ 2024-01-29 599/week @ 2024-02-05 556/week @ 2024-02-12 279/week @ 2024-02-19 812/week @ 2024-02-26 741/week @ 2024-03-04 794/week @ 2024-03-11 350/week @ 2024-03-18 443/week @ 2024-03-25 589/week @ 2024-04-01 341/week @ 2024-04-08 564/week @ 2024-04-15 623/week @ 2024-04-22 665/week @ 2024-04-29 256/week @ 2024-05-06

2,132 downloads per month
Used in 31 crates (6 directly)

MIT license

1MB
26K SLoC

noodles-bam handles the reading and writing of the BAM (Binary Alignment/Map) file format.

The BAM format contains the same information as SAM (Sequence Alignment/Map), namely a SAM header and a list of records.

Examples

Read all records

use noodles_bam as bam;

let mut reader = bam::io::reader::Builder::default().build_from_path("sample.bam")?;
let header = reader.read_header()?;

for result in reader.records() {
    let record = result?;
    // ...
}

Query records

Querying allows filtering records by region. It requires an associated BAM index (BAI).

use noodles_bam as bam;

let mut reader = bam::io::indexed_reader::Builder::default().build_from_path("sample.bam")?;
let header = reader.read_header()?;

let region = "sq0:5-8".parse()?;
let query = reader.query(&header, &region)?;

for result in query {
    let record = result?;
    // ...
}

Dependencies

~2.8–5MB
~80K SLoC