zellkonverter 1.19.2
This package provides a lightweight interface between the Bioconductor
SingleCellExperiment data structure and the Python AnnData-based single-cell
analysis environment. The idea is to enable users and developers to easily move
data between these frameworks to construct a multi-language analysis pipeline
across R/Bioconductor and Python.
The readH5AD() function can be used to read a SingleCellExperiment from a
H5AD file. This can be manipulated in the usual way as described in the
SingleCellExperiment documentation.
library(zellkonverter)
# Obtaining an example H5AD file.
example_h5ad <- system.file(
    "extdata", "krumsiek11.h5ad",
    package = "zellkonverter"
)
readH5AD(example_h5ad)## class: SingleCellExperiment 
## dim: 11 640 
## metadata(2): highlights iroot
## assays(1): X
## rownames(11): Gata2 Gata1 ... EgrNab Gfi1
## rowData names(0):
## colnames(640): 0 1 ... 158-3 159-3
## colData names(1): cell_type
## reducedDimNames(0):
## mainExpName: NULL
## altExpNames(0):We can also write a SingleCellExperiment to a H5AD file with the
writeH5AD() function. This is demonstrated below on the classic Zeisel mouse
brain dataset from the scRNAseq package. The resulting file can
then be directly used in compatible Python-based analysis frameworks.
library(scRNAseq)
sce_zeisel <- ZeiselBrainData()
out_path <- tempfile(pattern = ".h5ad")
writeH5AD(sce_zeisel, file = out_path)SingleCellExperiment and AnnData objectsDevelopers and power users who control their Python environments can directly
convert between SingleCellExperiment and
AnnData objects using the
SCE2AnnData() and AnnData2SCE() utilities. These functions expect that
reticulate has already been loaded along with an appropriate
version of the anndata package. We
suggest using the basilisk package to set up the Python
environment before using these functions.
library(basilisk)
library(scRNAseq)
seger <- SegerstolpePancreasData()
roundtrip <- basiliskRun(fun = function(sce) {
    # Convert SCE to AnnData:
    adata <- SCE2AnnData(sce)
    # Maybe do some work in Python on 'adata':
    # BLAH BLAH BLAH
    # Convert back to an SCE:
    AnnData2SCE(adata)
}, env = zellkonverterAnnDataEnv(), sce = seger)Package developers can guarantee that they are using the same versions of Python
packages as zellkonverter by using the AnnDataDependencies()
function to set up their Python environments.
AnnDataDependencies()## [1] "python=3.13.3"   "anndata==0.11.4" "h5py==3.14.0"    "natsort==8.4.0" 
## [5] "numpy==2.3.0"    "pandas==2.3.0"   "scipy==1.15.3"This function can also be used to return dependencies for environments using older versions of anndata.
AnnDataDependencies(version = "0.7.6")## [1] "python==3.9.23" "anndata==0.7.6" "h5py==3.14.0"   "natsort==8.4.0"
## [5] "numpy==1.26.4"  "pandas==1.5.3"  "scipy==1.13.1"By default the functions in zellkonverter don’t display any
information about their progress but this can be turned on by setting the
verbose = TRUE argument.
readH5AD(example_h5ad, verbose = TRUE)## class: SingleCellExperiment 
## dim: 11 640 
## metadata(2): highlights iroot
## assays(1): X
## rownames(11): Gata2 Gata1 ... EgrNab Gfi1
## rowData names(0):
## colnames(640): 0 1 ... 158-3 159-3
## colData names(1): cell_type
## reducedDimNames(0):
## mainExpName: NULL
## altExpNames(0):If you would like to see progress messages for all functions by default you can
turn this on using the setZellkonverterVerbose() function.
# This is not run here
setZellkonverterVerbose(TRUE)sessionInfo()## R version 4.5.1 Patched (2025-08-23 r88802)
## Platform: x86_64-pc-linux-gnu
## Running under: Ubuntu 24.04.3 LTS
## 
## Matrix products: default
## BLAS:   /home/biocbuild/bbs-3.22-bioc/R/lib/libRblas.so 
## LAPACK: /usr/lib/x86_64-linux-gnu/lapack/liblapack.so.3.12.0  LAPACK version 3.12.0
## 
## locale:
##  [1] LC_CTYPE=en_US.UTF-8       LC_NUMERIC=C              
##  [3] LC_TIME=en_GB              LC_COLLATE=C              
##  [5] LC_MONETARY=en_US.UTF-8    LC_MESSAGES=en_US.UTF-8   
##  [7] LC_PAPER=en_US.UTF-8       LC_NAME=C                 
##  [9] LC_ADDRESS=C               LC_TELEPHONE=C            
## [11] LC_MEASUREMENT=en_US.UTF-8 LC_IDENTIFICATION=C       
## 
## time zone: America/New_York
## tzcode source: system (glibc)
## 
## attached base packages:
## [1] stats4    stats     graphics  grDevices utils     datasets  methods  
## [8] base     
## 
## other attached packages:
##  [1] basilisk_1.21.5             reticulate_1.43.0          
##  [3] scRNAseq_2.23.0             SingleCellExperiment_1.31.1
##  [5] SummarizedExperiment_1.39.2 Biobase_2.69.1             
##  [7] GenomicRanges_1.61.5        Seqinfo_0.99.2             
##  [9] IRanges_2.43.5              S4Vectors_0.47.4           
## [11] BiocGenerics_0.55.1         generics_0.1.4             
## [13] MatrixGenerics_1.21.0       matrixStats_1.5.0          
## [15] zellkonverter_1.19.2        knitr_1.50                 
## [17] BiocStyle_2.37.1           
## 
## loaded via a namespace (and not attached):
##  [1] DBI_1.2.3                bitops_1.0-9             httr2_1.2.1             
##  [4] rlang_1.1.6              magrittr_2.0.4           gypsum_1.5.0            
##  [7] compiler_4.5.1           RSQLite_2.4.3            GenomicFeatures_1.61.6  
## [10] dir.expiry_1.17.0        png_0.1-8                vctrs_0.6.5             
## [13] ProtGenerics_1.41.0      pkgconfig_2.0.3          crayon_1.5.3            
## [16] fastmap_1.2.0            dbplyr_2.5.1             XVector_0.49.1          
## [19] Rsamtools_2.25.3         rmarkdown_2.30           UCSC.utils_1.5.0        
## [22] bit_4.6.0                xfun_0.53                cachem_1.1.0            
## [25] GenomeInfoDb_1.45.12     jsonlite_2.0.0           blob_1.2.4              
## [28] rhdf5filters_1.21.0      DelayedArray_0.35.3      Rhdf5lib_1.31.0         
## [31] BiocParallel_1.43.4      parallel_4.5.1           R6_2.6.1                
## [34] bslib_0.9.0              rtracklayer_1.69.1       jquerylib_0.1.4         
## [37] Rcpp_1.1.0               bookdown_0.45            Matrix_1.7-4            
## [40] tidyselect_1.2.1         abind_1.4-8              yaml_2.3.10             
## [43] codetools_0.2-20         curl_7.0.0               alabaster.sce_1.9.0     
## [46] lattice_0.22-7           tibble_3.3.0             KEGGREST_1.49.1         
## [49] evaluate_1.0.5           BiocFileCache_2.99.6     alabaster.schemas_1.9.0 
## [52] ExperimentHub_2.99.5     Biostrings_2.77.2        pillar_1.11.1           
## [55] BiocManager_1.30.26      filelock_1.0.3           RCurl_1.98-1.17         
## [58] BiocVersion_3.22.0       ensembldb_2.33.2         alabaster.base_1.9.5    
## [61] alabaster.ranges_1.9.1   glue_1.8.0               alabaster.matrix_1.9.0  
## [64] lazyeval_0.2.2           tools_4.5.1              AnnotationHub_3.99.6    
## [67] BiocIO_1.19.0            GenomicAlignments_1.45.4 XML_3.99-0.19           
## [70] rhdf5_2.53.5             grid_4.5.1               AnnotationDbi_1.71.1    
## [73] HDF5Array_1.37.0         restfulr_0.0.16          cli_3.6.5               
## [76] rappdirs_0.3.3           S4Arrays_1.9.1           dplyr_1.1.4             
## [79] AnnotationFilter_1.33.0  alabaster.se_1.9.0       sass_0.4.10             
## [82] digest_0.6.37            SparseArray_1.9.1        rjson_0.2.23            
## [85] memoise_2.0.1            htmltools_0.5.8.1        lifecycle_1.0.4         
## [88] h5mread_1.1.1            httr_1.4.7               bit64_4.6.0-1