Apache POIで普段使うのは'User API'というAPIのようですが、 このAPIを利用して大きなファイルを扱おうとすると大量のメモリを必要とし、OutOfMemoryが発生します。 この問題を回避するには、 ヒープ領域を増やして実行する Event APIを使う Streaming User APIを使う xlsxファイルを解凍して中身のxmlファイルを処理する といった解決方法があるようです。 ためしに、Clojure+Apache POIでEvent APIを利用したコードを書いてみます。 ぱっと見た限りではxlsxファイルを解凍して処理する手間の一部を省いてくれているだけのようです。 ;; project.clj (defproject poixml "0.1.0-SNAPSHOT" :description "dummy" :url "dummy" :license {