dycw-utilities 0.159.7__py3-none-any.whl → 0.159.8__py3-none-any.whl

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.4
2
2
  Name: dycw-utilities
3
- Version: 0.159.7
3
+ Version: 0.159.8
4
4
  Author-email: Derek Wan <d.wan@icloud.com>
5
5
  License-File: LICENSE
6
6
  Requires-Python: >=3.12
@@ -1,4 +1,4 @@
1
- utilities/__init__.py,sha256=56_sf0hO601aZOcezRa7sifQnNq2J9UBn2u-2N4z3x0,60
1
+ utilities/__init__.py,sha256=ZNV6cnMhMqb35heJ2XDn7MrYezCm7WhHn0JLWgxfK3c,60
2
2
  utilities/altair.py,sha256=92E2lCdyHY4Zb-vCw6rEJIsWdKipuu-Tu2ab1ufUfAk,9079
3
3
  utilities/asyncio.py,sha256=PUedzQ5deqlSECQ33sam9cRzI9TnygHz3FdOqWJWPTM,15288
4
4
  utilities/atomicwrites.py,sha256=tPo6r-Rypd9u99u66B9z86YBPpnLrlHtwox_8Z7T34Y,5790
@@ -45,7 +45,7 @@ utilities/parse.py,sha256=JcJn5yXKhIWXBCwgBdPsyu7Hvcuw6kyEdqvaebCaI9k,17951
45
45
  utilities/pathlib.py,sha256=qGuU8XPmdgGpy8tOMUgelfXx3kxI8h9IaV3TI_06QGE,8428
46
46
  utilities/pickle.py,sha256=MBT2xZCsv0pH868IXLGKnlcqNx2IRVKYNpRcqiQQqxw,653
47
47
  utilities/platform.py,sha256=pTn7gw6N4T6LdKrf0virwarof_mze9WtoQlrGMzhGVI,2798
48
- utilities/polars.py,sha256=sPi-h2G-Nv6nykgK4_4Gg4lYEpy1F3F3KWswEASu6zw,79756
48
+ utilities/polars.py,sha256=aDICWXSOP8F1P40kS3C7vIUY9RDVceOEdhDxYBWOv_8,80518
49
49
  utilities/polars_ols.py,sha256=Uc9V5kvlWZ5cU93lKZ-cfAKdVFFw81tqwLW9PxtUvMs,5618
50
50
  utilities/postgres.py,sha256=ynCTTaF-bVEOSW-KEAR-dlLh_hYjeVVjm__-4pEU8Zk,12269
51
51
  utilities/pottery.py,sha256=ggMN72Y7wx7Js8VN6eyNyodpm8TIYqZHGghkDPXIVWk,3949
@@ -87,8 +87,8 @@ utilities/zoneinfo.py,sha256=FBMcUQ4662Aq8SsuCL1OAhDQiyANmVjtb-C30DRrWoE,1966
87
87
  utilities/pytest_plugins/__init__.py,sha256=U4S_2y3zgLZVfMenHRaJFBW8yqh2mUBuI291LGQVOJ8,35
88
88
  utilities/pytest_plugins/pytest_randomly.py,sha256=B1qYVlExGOxTywq2r1SMi5o7btHLk2PNdY_b1p98dkE,409
89
89
  utilities/pytest_plugins/pytest_regressions.py,sha256=9v8kAXDM2ycIXJBimoiF4EgrwbUvxTycFWJiGR_GHhM,1466
90
- dycw_utilities-0.159.7.dist-info/METADATA,sha256=iitOcQmUpaHfUZKp0sZ7xCjberrrfy1KUdA02FD72y4,1643
91
- dycw_utilities-0.159.7.dist-info/WHEEL,sha256=qtCwoSJWgHk21S1Kb4ihdzI2rlJ1ZKaIurTj_ngOhyQ,87
92
- dycw_utilities-0.159.7.dist-info/entry_points.txt,sha256=BOD_SoDxwsfJYOLxhrSXhHP_T7iw-HXI9f2WVkzYxvQ,135
93
- dycw_utilities-0.159.7.dist-info/licenses/LICENSE,sha256=gppZp16M6nSVpBbUBrNL6JuYfvKwZiKgV7XoKKsHzqo,1066
94
- dycw_utilities-0.159.7.dist-info/RECORD,,
90
+ dycw_utilities-0.159.8.dist-info/METADATA,sha256=m2wmC4GlUq04TCY6GANKluJqCEl9MLw8XruIEQhM8Ew,1643
91
+ dycw_utilities-0.159.8.dist-info/WHEEL,sha256=qtCwoSJWgHk21S1Kb4ihdzI2rlJ1ZKaIurTj_ngOhyQ,87
92
+ dycw_utilities-0.159.8.dist-info/entry_points.txt,sha256=BOD_SoDxwsfJYOLxhrSXhHP_T7iw-HXI9f2WVkzYxvQ,135
93
+ dycw_utilities-0.159.8.dist-info/licenses/LICENSE,sha256=gppZp16M6nSVpBbUBrNL6JuYfvKwZiKgV7XoKKsHzqo,1066
94
+ dycw_utilities-0.159.8.dist-info/RECORD,,
utilities/__init__.py CHANGED
@@ -1,3 +1,3 @@
1
1
  from __future__ import annotations
2
2
 
3
- __version__ = "0.159.7"
3
+ __version__ = "0.159.8"
utilities/polars.py CHANGED
@@ -2446,6 +2446,31 @@ class RoundToFloatError(Exception):
2446
2446
  ##
2447
2447
 
2448
2448
 
2449
+ def select_exact(
2450
+ df: DataFrame, /, *columns: IntoExprColumn, drop: MaybeIterable[str] | None = None
2451
+ ) -> DataFrame:
2452
+ """Select an exact set of columns from a DataFrame."""
2453
+ names = [get_expr_name(df, c) for c in columns]
2454
+ drop = set() if drop is None else set(always_iterable(drop))
2455
+ union = set(names) | drop
2456
+ extra = [c for c in df.columns if c not in union]
2457
+ if len(extra) >= 1:
2458
+ raise SelectExactError(columns=extra)
2459
+ return df.select(*columns)
2460
+
2461
+
2462
+ @dataclass(kw_only=True, slots=True)
2463
+ class SelectExactError(Exception):
2464
+ columns: list[str]
2465
+
2466
+ @override
2467
+ def __str__(self) -> str:
2468
+ return f"All columns must be selected; got {get_repr(self.columns)} remaining"
2469
+
2470
+
2471
+ ##
2472
+
2473
+
2449
2474
  def set_first_row_as_columns(df: DataFrame, /) -> DataFrame:
2450
2475
  """Set the first row of a DataFrame as its columns."""
2451
2476
  try:
@@ -2654,6 +2679,7 @@ __all__ = [
2654
2679
  "OneColumnError",
2655
2680
  "OneColumnNonUniqueError",
2656
2681
  "RoundToFloatError",
2682
+ "SelectExactError",
2657
2683
  "SetFirstRowAsColumnsError",
2658
2684
  "TimePeriodDType",
2659
2685
  "acf",
@@ -2709,6 +2735,7 @@ __all__ = [
2709
2735
  "read_series",
2710
2736
  "replace_time_zone",
2711
2737
  "round_to_float",
2738
+ "select_exact",
2712
2739
  "serialize_dataframe",
2713
2740
  "set_first_row_as_columns",
2714
2741
  "struct_dtype",