arrow2 VS pyodide

Compare arrow2 vs pyodide and see what are their differences.

arrow2

Transmute-free Rust library to work with the Arrow format (by jorgecarleitao)

pyodide

Pyodide is a Python distribution for the browser and Node.js based on WebAssembly (by iodide-project)
Our great sponsors
  • InfluxDB - Power Real-Time Data Analytics at Scale
  • WorkOS - The modern identity platform for B2B SaaS
  • SaaSHub - Software Alternatives and Reviews
arrow2 pyodide
25 67
1,071 11,375
- 2.6%
0.0 9.7
2 months ago 6 days ago
Rust Python
Apache License 2.0 Mozilla Public License 2.0
The number of mentions indicates the total number of mentions that we've tracked plus the number of user suggested alternatives.
Stars - the number of stars that a project has on GitHub. Growth - month over month growth in stars.
Activity is a relative number indicating how actively a project is being developed. Recent commits have higher weight than older ones.
For example, an activity of 9.0 indicates that a project is amongst the top 10% of the most actively developed projects that we are tracking.

arrow2

Posts with mentions or reviews of arrow2. We have used some of these posts to build our list of alternatives and similar projects. The last one was on 2023-08-03.
  • Polars: Company Formation Announcement
    3 projects | news.ycombinator.com | 3 Aug 2023
    One of the interesting components of Polars that I've been watching is the use of the Apache Arrow memory format, which is a standard layout for data in memory that enables processing (querying, iterating, calculating, etc) in a language agnostic way, in particular without having to copy/convert it into the local object format first. This enables cross-language data access by mmaping or transferring a single buffer, with zero [de]serialization overhead.

    For some history, there's has been a bit of contention between the official arrow-rs implementation and the arrow2 implementation created by the polars team which includes some extra features that they find important. I think the current status is that everyone agrees that having two crates that implement the same standard is not ideal, and they are working to port any necessary features to the arrow-rs crate and plan on eventually switching to it and deprecating arrow2. But that's not easy.

    https://github.com/apache/arrow-rs/issues/1176

    https://github.com/jorgecarleitao/arrow2/pull/1476

  • Data Engineering with Rust
    5 projects | /r/rust | 9 May 2023
    https://github.com/jorgecarleitao/arrow2 https://github.com/apache/arrow-datafusion https://github.com/apache/arrow-ballista https://github.com/pola-rs/polars https://github.com/duckdb/duckdb
  • Polars[Query Engine/ DataFrame] 0.28.0 released :)
    3 projects | /r/rust | 29 Mar 2023
    Currently datafusion and polars aren't directly operable iirc because they use different underlying arrows implementations, but there seems to be work being done on that here https://github.com/jorgecarleitao/arrow2/issues/1429
  • Arrow2 0.15 has been released. Happy festivities everyone =)
    1 project | /r/rust | 18 Dec 2022
  • Rust is showing a lot of promise in the DataFrame / tabular data space
    9 projects | /r/rust | 4 Oct 2022
    [arrow2](https://github.com/jorgecarleitao/arrow2) and [parquet2](https://github.com/jorgecarleitao/parquet2) are great foundational libraries for and DataFrame libs in Rust.
  • Matano - Open source security lake built with Arrow2 + Rust
    2 projects | /r/rust | 3 Oct 2022
    [1] https://github.com/jorgecarleitao/arrow2
  • Polars 0.23.0 released
    3 projects | /r/rust | 4 Aug 2022
    In lockstep with arrow2's 0.13 release, we have published polars 0.23.0.
  • Arrow2 v0.13.0, now with support to read Apache ORC and COW semantics!
    1 project | /r/rust | 31 Jul 2022
  • ::lending-iterator — Lending/streaming Iterators on Stable Rust (and a pinch of HKT)
    3 projects | /r/rust | 20 Jul 2022
    This is so freaking life-saving! - we have been using StreamingIterator and FallibleStreamingIterator in libraries (arrow2 and parquet2) and the existing landscape is quite confusing for new users!
  • Mssql :(
    1 project | /r/rust | 9 Jun 2022
    arrow2 has support for mssql via ODBC (which microsoft has first class support to). Here are the integration tests we have (both read and write) against mssql specifically.

pyodide

Posts with mentions or reviews of pyodide. We have used some of these posts to build our list of alternatives and similar projects. The last one was on 2024-04-22.
  • Py2wasm – A Python to WASM Compiler
    4 projects | news.ycombinator.com | 22 Apr 2024
    We implemented an in-browser Python editor/interpreter built on Pyodide over at Comet (our users are data scientists who need to build custom visualizations quite often, and the most familiar language for most of them is Python).

    One of the issues you'll run into is that Pyodide only works by default with packages that have pure Python wheels available. The team has developed support for some libraries with C dependencies (like scikit-learn, I believe), but frameworks like PyTorch are particularly thorny (see this issue: https://github.com/pyodide/pyodide/issues/1625 )

    We ended up rolling out a new version of our Python visualizations that runs off-browser, in order to support enough libraries/get the performance we need: https://www.comet.com/docs/v2/guides/comet-ui/experiment-man...

  • Show HN: Open-source, browser-local data exploration using DuckDB-WASM and PRQL
    11 projects | news.ycombinator.com | 15 Mar 2024
    Thank you! Yes, one of the items in the Roadmap is support for Pyodide (https://github.com/pyodide/pyodide) for running in-browser python on the results of each of the code blocks! This should allow most ML libs to be usable in-browser! This is pretty high-up on our priority list.
  • Show HN: Marimo – open-source reactive Python notebook – running in WASM
    3 projects | news.ycombinator.com | 29 Feb 2024
  • Why Are Tech Reporters Sleeping on the Biggest App Store Story?
    6 projects | news.ycombinator.com | 2 Jan 2024
    If I understand correctly, WASM only makes sense for compiled languages, you can run the python interpreter in WASM of course[1], but that will be at a significant performance disadvantage to the native javascript interpreter, and it's also something that has to be loaded every time you load the website.

    [1]: https://github.com/pyodide/pyodide

  • Rewrite Sympy in rust
    2 projects | /r/rust | 11 Nov 2023
    If you absolutely need something comparable to Sympy, then one option might be to figure out how to best call Sympy from Rust. e.g. - RustPython, although it seems like Sympy isn't supported yet - Pyodide, and figuring out how to run it outside of a web browser. Probably also not very easy. - PyPy, and having a pretty simple Python binary for every platform - ...
  • IT department refuses to let me install Python and other programs/languages I need for my job.
    2 projects | /r/webdev | 19 Jun 2023
    For running programming languages other than JavaScript in the browser there is Emscripten and WebAssembly. There is v86, where a Linux build is compiled to WASM. Folks have written QuickJS into a Linux build compiled to WASM, Node.js into the Linux buildroot https://github.com/cemalgnlts/now, so Python or CPython can be written to the image and loaded into the browser as WASM as well https://github.com/pyodide/pyodide.
  • Python CLI Live Demo?
    1 project | /r/learnpython | 31 May 2023
  • Graphs in Python web app
    5 projects | /r/Python | 28 Mar 2023
    There's a Python runtime that runs on WebAssembly (https://github.com/pyodide/pyodide). I have no idea what it's like, I've never used it.
  • Sunday Daily Thread: What's everyone working on this week?
    7 projects | /r/Python | 25 Mar 2023
    Still in a quest to provide some tooling to quickly compose documentation websites: https://github.com/synw/docdundee . As I have tons of libs to document and was tired of managing restructured language for readthedocs I started with this, and now it has executable Python examples in the frontend via a Pyodide wrapper composable: usePython
  • Introducing scikit-learn-ts: A powerful machine learning library for TS, auto-generated and powered by Python's #1 ML library
    3 projects | /r/typescript | 13 Mar 2023
    This project's brand new and a lil hacky, but I've already reached out to the scikit-learn team, and they recommended that I experiment with using Pyodide as an alternative backend for the Python bridge.

What are some alternatives?

When comparing arrow2 and pyodide you can also consider the following projects:

polars - Dataframes powered by a multithreaded, vectorized query engine, written in Rust

brython - Brython (Browser Python) is an implementation of Python 3 running in the browser

arrow-datafusion - Apache DataFusion SQL Query Engine

pyscript - Try PyScript: https://pyscript.com Examples: https://tinyurl.com/pyscript-examples Community: https://discord.gg/HxvBtukrg2

db-benchmark - reproducible benchmark of database-like ops

RustPython - A Python Interpreter written in Rust

arrow-rs - Official Rust implementation of Apache Arrow

streamlit - Streamlit — A faster way to build and share data apps.

explorer - Series (one-dimensional) and dataframes (two-dimensional) for fast and elegant data exploration in Elixir

Transcrypt - Python 3.9 to JavaScript compiler - Lean, fast, open! -

datafuse - An elastic and reliable Cloud Warehouse, offers Blazing Fast Query and combines Elasticity, Simplicity, Low cost of the Cloud, built to make the Data Cloud easy [Moved to: https://github.com/datafuselabs/databend]

PyWebIO - Write interactive web app in script way.