CARVIEW |
Select Language
HTTP/2 200
date: Wed, 30 Jul 2025 20:14:16 GMT
content-type: text/html; charset=utf-8
vary: X-PJAX, X-PJAX-Container, Turbo-Visit, Turbo-Frame, X-Requested-With,Accept-Encoding, Accept, X-Requested-With
etag: W/"467c44589da0011b06d2a93f26954fb2"
cache-control: max-age=0, private, must-revalidate
strict-transport-security: max-age=31536000; includeSubdomains; preload
x-frame-options: deny
x-content-type-options: nosniff
x-xss-protection: 0
referrer-policy: no-referrer-when-downgrade
content-security-policy: default-src 'none'; base-uri 'self'; child-src github.githubassets.com github.com/assets-cdn/worker/ github.com/assets/ gist.github.com/assets-cdn/worker/; connect-src 'self' uploads.github.com www.githubstatus.com collector.github.com raw.githubusercontent.com api.github.com github-cloud.s3.amazonaws.com github-production-repository-file-5c1aeb.s3.amazonaws.com github-production-upload-manifest-file-7fdce7.s3.amazonaws.com github-production-user-asset-6210df.s3.amazonaws.com *.rel.tunnels.api.visualstudio.com wss://*.rel.tunnels.api.visualstudio.com objects-origin.githubusercontent.com copilot-proxy.githubusercontent.com proxy.individual.githubcopilot.com proxy.business.githubcopilot.com proxy.enterprise.githubcopilot.com *.actions.githubusercontent.com wss://*.actions.githubusercontent.com productionresultssa0.blob.core.windows.net/ productionresultssa1.blob.core.windows.net/ productionresultssa2.blob.core.windows.net/ productionresultssa3.blob.core.windows.net/ productionresultssa4.blob.core.windows.net/ productionresultssa5.blob.core.windows.net/ productionresultssa6.blob.core.windows.net/ productionresultssa7.blob.core.windows.net/ productionresultssa8.blob.core.windows.net/ productionresultssa9.blob.core.windows.net/ productionresultssa10.blob.core.windows.net/ productionresultssa11.blob.core.windows.net/ productionresultssa12.blob.core.windows.net/ productionresultssa13.blob.core.windows.net/ productionresultssa14.blob.core.windows.net/ productionresultssa15.blob.core.windows.net/ productionresultssa16.blob.core.windows.net/ productionresultssa17.blob.core.windows.net/ productionresultssa18.blob.core.windows.net/ productionresultssa19.blob.core.windows.net/ github-production-repository-image-32fea6.s3.amazonaws.com github-production-release-asset-2e65be.s3.amazonaws.com insights.github.com wss://alive.github.com wss://alive-staging.github.com api.githubcopilot.com api.individual.githubcopilot.com api.business.githubcopilot.com api.enterprise.githubcopilot.com; font-src github.githubassets.com; form-action 'self' github.com gist.github.com copilot-workspace.githubnext.com objects-origin.githubusercontent.com; frame-ancestors 'none'; frame-src viewscreen.githubusercontent.com notebooks.githubusercontent.com; img-src 'self' data: blob: github.githubassets.com media.githubusercontent.com camo.githubusercontent.com identicons.github.com avatars.githubusercontent.com private-avatars.githubusercontent.com github-cloud.s3.amazonaws.com objects.githubusercontent.com release-assets.githubusercontent.com secured-user-images.githubusercontent.com/ user-images.githubusercontent.com/ private-user-images.githubusercontent.com opengraph.githubassets.com copilotprodattachments.blob.core.windows.net/github-production-copilot-attachments/ github-production-user-asset-6210df.s3.amazonaws.com customer-stories-feed.github.com spotlights-feed.github.com objects-origin.githubusercontent.com *.githubusercontent.com; manifest-src 'self'; media-src github.com user-images.githubusercontent.com/ secured-user-images.githubusercontent.com/ private-user-images.githubusercontent.com github-production-user-asset-6210df.s3.amazonaws.com gist.github.com; script-src github.githubassets.com; style-src 'unsafe-inline' github.githubassets.com; upgrade-insecure-requests; worker-src github.githubassets.com github.com/assets-cdn/worker/ github.com/assets/ gist.github.com/assets-cdn/worker/
server: github.com
content-encoding: gzip
accept-ranges: bytes
set-cookie: _gh_sess=ms4WzdIig9C5P8sBfGi0kQxfNJpkfVoDnqIeajLbrBOKzuAwr8BeTq5LIRroBAJzpgCCbAuCM2BoBa7iY5tViKR%2BPOyG4YnU8pjHiDuqsI9M6w395s%2Fu7%2BSoWObTtlfLHPqszygFf%2FvvIbSRonhD96uFMlg9lMbW%2Bo%2BNjJpD6ED0hu8xzR6VJqsgrGUIHNPW2ZlFG5cAW0eiR6ykg0w%2FFEt9L3sw6NeDIr%2Fls2KwaiZZlu3XuEOP2Pe8LuwAeLMXKv9dzSKZEeUdSMEIxxVp3Q%3D%3D--c3%2F8R%2FX6zIAA34m5--OfvKKRFeHw0EPW7Rglhb7g%3D%3D; Path=/; HttpOnly; Secure; SameSite=Lax
set-cookie: _octo=GH1.1.1274151484.1753906456; Path=/; Domain=github.com; Expires=Thu, 30 Jul 2026 20:14:16 GMT; Secure; SameSite=Lax
set-cookie: logged_in=no; Path=/; Domain=github.com; Expires=Thu, 30 Jul 2026 20:14:16 GMT; HttpOnly; Secure; SameSite=Lax
x-github-request-id: EADE:9EA30:98F9F:C7A86:688A7D18
Release Rust Polars 0.49.0 Β· pola-rs/polars Β· GitHub
Loading
Skip to content
Navigation Menu
{{ message }}
-
-
Notifications
You must be signed in to change notification settings - Fork 2.3k
Rust Polars 0.49.0
Compare
·
48 commits
to 071bd761ae1188924ee2cdf3b526e88e3476bdc2
since this release
3e35098
This commit was created on GitHub.com and signed with GitHubβs verified signature.
π₯ Breaking changes
- Remove old streaming engine (#23103)
π Performance improvements
- Improve streaming groupby CSE (#23092)
- Move row index materialization in post-apply to occur after slicing (#22995)
- Add first_(true|false)_idx to BooleanChunked and use in bool arg_(min|max) (#22907)
- Don't go through row encoding for most types on
index_of
(#22903) - Optimise low-level
null
scans andarg_max
for bools (when chunked) (#22897) - Optimize multiscan performance (#22886)
β¨ Enhancements
- Native implementation for Iceberg positional deletes (#23091)
- Remove old streaming engine (#23103)
- Make match_chunks public (#23101)
- Implement StructFunction expressions in into_py (#23022)
- Basic implementation of
DataTypeExpr
in Rust DSL (#23049) - Add
required: bool
toParquetFieldOverwrites
(#23013) - Support serializing
name.map_fields
(#22997) - Support serializing
Expr::RenameAlias
(#22988) - Remove duplicate verbose logging from
FetchedCredentialsCache
(#22973) - Add
keys
column infinish_callback
(#22968) - Add
extra_columns
parameter toscan_parquet
(#22699) - Add CORR function to polars SQL (#22690)
- Add per partition sort and finish callback to sinks (#22789)
- Add and test DataFrame equality functionality (#22865)
- Support descendingly-sorted values in search_sorted() (#22825)
- Derive DSL schema (#22866)
π Bug fixes
- Restrict custom
aggregate_function
inpivot
topl.element()
(#23155) - Don't leak
SourceToken
in in-memory sink linearize (#23201) - Fix panic reading empty parquet with multiple boolean columns (#23159)
- Raise ComputeError instead of panicking in
truncate
when mixing month/week/day/sub-daily units (#23176) - Materialize
list.eval
with unknown type (#23186) - Only set sorting flag for 1st column with PQ SortingColumns (#23184)
- Typo in AExprBuilder (#23171)
- Null return from var/std on scalar column (#23158)
- Support Datetime broadcast in
list.concat
(#23137) - Ensure projection pushdown maintains right table schema (#22603)
- Don't create i128 scalars if dtype-128 is not set (#23118)
- Add Null dtype support to arg_sort_by (#23107)
- Raise error by default on invalid CSV quotes (#22876)
- Fix group_by mean and median returning all nulls for Decimal dtype (#23093)
- Fix hive partition pruning not filtering out
__HIVE_DEFAULT_PARTITION__
(#23074) - Fix
AssertionError
when usingscan_delta()
on AWS withstorage_options
(#23076) - Fix deadlock on
collect(background=True)
/collect_concurrently()
(#23075) - Incorrect null count in rolling_min/max (#23073)
- Preserve
file://
in LazyFrame node traverser (#23072) - Respect column order in
register_io_source
schema (#23057) - Incorrect output when using
sort
withgroup_by
andcum_sum
(#23001) - Implement owned arithmetic for Int128 (#23055)
- Do not schema-match structs with different field counts (#23018)
- Fix confusing error message on duplicate row_index (#23043)
- Add
include_nulls
toAgg::Count
CSE check (#23032) - View buffer exceeding 2^32 - 1 bytes in concatenate_view (#23017)
- Fix incorrect
size_hint()
forFlatIter
(#23010) - Fix incorrect result selecting
pl.len()
fromscan_csv
withskip_lines
(#22949) - Allow for IO plugins with reordered columns in streaming (#22987)
- Method
str.zfill
was inconsistent with Python and pandas when string contained leading '+' (#22985) - Integer underflow in
propagate_nulls
(#22986) - Fix cum_min and cum_max does not preserve inf or -inf values at series start (#22896)
- Setting
compat_level=0
forsink_ipc
(#22960) - Support arrow Decimal32 and Decimal64 types (#22954)
- Update arrow format (#22941)
- Fix filter pushdown to IO plugins (#22910)
- Improve numeric stability rolling_mean<f32> (#22944)
- Allow subclasses in type equality checking (#22915)
- Return early in
pl.Expr.__array_ufunc__
when only single input (#22913) - Add inline implodes in type coercion (#22885)
- Correct
int_ranges
to raise error on invalid inputs (#22894) - Set the sorted flag on Array after it is sorted (#22822)
- Don't silently overflow for temporal casts (#22901)
- Fix error using
write_csv
withstorage_options
(#22881) - Schema resolution
.over(mapping_strategy="join")
with non-aggregations (#22875) - Ensure rename behaves the same as select (#22852)
π Documentation
- Update when_then in user guide (#23245)
- Minor improvement to
cum_count
docstring example (#23099) - Add missing entry for LazyFrame
__getitem__
(#22924)
π¦ Build system
- Actually disable
ir_serde
by default (#23046) - Add a feature flag for
serde_ignored
(#22957) - Fix warnings, update DSL version and schema hash (#22953)
π οΈ Other improvements
- Update Rust Polars versions (#23229)
- Change flake to use venv (#23219)
- Add
default_alloc
feature topy-polars
(#23202) - Added more descriptive error message by replacing
FixedSizeList
withArray
(#23168) - Connect Python
assert_series_equal()
to Rust back-end (#23141) - Refactor skip_batches to use AExprBuilder (#23147)
- Use
ir_serde
instead ofserde
forIRFunctionExpr
(#23148) - Separate
FunctionExpr
andIRFunctionExpr
(#23140) - Improve Series equality functionality and prepare for Python integration (#23136)
- Add PolarsPhysicalType and use it to dispatch into_series (#23080)
- Remove
AExpr::Alias
(#23070) - Add components for Iceberg deletion file support (#23059)
- Feature gate
StructFunction::JsonEncode
(#23060) - Propagate iceberg position delete information to IR (#23045)
- Add environment variable to get Parquet decoding metrics (#23052)
- Turn
pl.cumulative_eval
into its ownAExpr
(#22994) - Add make test-streaming (#23044)
- Move scan parameter parsing for parquet to reusable function (#23019)
- Use a ref-counted
UniqueId
instead ofusize
forcache_id
(#22984) - Implement
Hash
and useSpecialEq
forRenameAliasFn
(#22989) - Turn
list.eval
into anAExpr
(#22911) - Only check for unknown DSL fields if minor is higher (#22970)
- Don't enable
ir_serde
together withserde
(#22969) - Make dtype field on Logical non-optional (#22966)
- Add new (Frozen)Categories and CategoricalMapping (#22956)
- Add a CI check for DSL schema changes (#22898)
- Add schema parameters to
expr.meta
(#22906) - Update rust toolchain in nix flake (#22905)
- Update toolchain (#22859)
Thank you to all our contributors for making this release possible!
@Athsus, @DahaoALG, @FabianWolff, @JakubValtar, @Kevin-Patyk, @MarcoGorelli, @SanjitBasker, @alexander-beedie, @borchero, @bschoenmaeckers, @cmdlineluser, @coastalwhite, @deanm0000, @dsprenkels, @eitsupi, @florian-klein, @i1oveMyse1f, @ion-elgreco, @itamarst, @kdn36, @kutal10, @math-hiyoko, @mcrumiller, @mrkn, @mroeschke, @nameexhaustion, @nikaltipar, @orlp, @paskhaver, @ritchie46, @stijnherfst, @thomasfrederikhoeck and @zyctree
Assets 2
1 person reacted
You canβt perform that action at this time.