pandas-plots 0.11.0__tar.gz → 0.11.2__tar.gz

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.1
2
2
  Name: pandas-plots
3
- Version: 0.11.0
3
+ Version: 0.11.2
4
4
  Summary: A collection of helper for table handling and vizualization
5
5
  Home-page: https://github.com/smeisegeier/pandas-plots
6
6
  Author: smeisegeier
@@ -26,10 +26,11 @@ Requires-Dist: matplotlib-venn>=0.11.10
26
26
  Requires-Dist: seaborn>=0.13.2
27
27
  Requires-Dist: Jinja2>=3.1.3
28
28
  Requires-Dist: requests>=2.31.0
29
+ Requires-Dist: numpy<2.0.0
29
30
 
30
31
  # pandas-plots
31
32
 
32
- ![PyPI - Version](https://img.shields.io/pypi/v/pandas-plots) ![GitHub last commit](https://img.shields.io/github/last-commit/smeisegeier/pandas-plots?logo=github) ![GitHub License](https://img.shields.io/github/license/smeisegeier/pandas-plots?logo=github) ![py3.10](https://img.shields.io/badge/python-3.10-blue.svg?logo=)
33
+ ![PyPI - Version](https://img.shields.io/pypi/v/pandas-plots) ![GitHub last commit](https://img.shields.io/github/last-commit/smeisegeier/pandas-plots?logo=github) ![GitHub License](https://img.shields.io/github/license/smeisegeier/pandas-plots?logo=github) ![py3.10](https://img.shields.io/badge/python-3.10_|_3.11_|_3.12-blue.svg?logo=)
33
34
 
34
35
  ## usage
35
36
 
@@ -98,8 +99,9 @@ tbl.show_num_df(
98
99
  - `mean_confidence_interval()` calculates mean and confidence interval for a series
99
100
  - `wrap_text()` formats strings or lists to a given width to fit nicely on the screen
100
101
  - `replace_delimiter_outside_quotes()` when manual import of csv files is needed: replaces delimiters only outside of quotes
101
- - 🆕 `create_barcode_from_url()` creates a barcode from a given URL
102
- - 🆕 `add_datetime_col()` adds a datetime columns to a dataframe
102
+ - `create_barcode_from_url()` creates a barcode from a given URL
103
+ - `add_datetime_col()` adds a datetime columns to a dataframe
104
+ - 🆕 `show_package_version` prints version of a list of packages
103
105
 
104
106
  > note: theme setting can be controlled through all functions by setting the environment variable `THEME` to either light or dark
105
107
 
@@ -1,6 +1,6 @@
1
1
  # pandas-plots
2
2
 
3
- ![PyPI - Version](https://img.shields.io/pypi/v/pandas-plots) ![GitHub last commit](https://img.shields.io/github/last-commit/smeisegeier/pandas-plots?logo=github) ![GitHub License](https://img.shields.io/github/license/smeisegeier/pandas-plots?logo=github) ![py3.10](https://img.shields.io/badge/python-3.10-blue.svg?logo=)
3
+ ![PyPI - Version](https://img.shields.io/pypi/v/pandas-plots) ![GitHub last commit](https://img.shields.io/github/last-commit/smeisegeier/pandas-plots?logo=github) ![GitHub License](https://img.shields.io/github/license/smeisegeier/pandas-plots?logo=github) ![py3.10](https://img.shields.io/badge/python-3.10_|_3.11_|_3.12-blue.svg?logo=)
4
4
 
5
5
  ## usage
6
6
 
@@ -69,8 +69,9 @@ tbl.show_num_df(
69
69
  - `mean_confidence_interval()` calculates mean and confidence interval for a series
70
70
  - `wrap_text()` formats strings or lists to a given width to fit nicely on the screen
71
71
  - `replace_delimiter_outside_quotes()` when manual import of csv files is needed: replaces delimiters only outside of quotes
72
- - 🆕 `create_barcode_from_url()` creates a barcode from a given URL
73
- - 🆕 `add_datetime_col()` adds a datetime columns to a dataframe
72
+ - `create_barcode_from_url()` creates a barcode from a given URL
73
+ - `add_datetime_col()` adds a datetime columns to a dataframe
74
+ - 🆕 `show_package_version` prints version of a list of packages
74
75
 
75
76
  > note: theme setting can be controlled through all functions by setting the environment variable `THEME` to either light or dark
76
77
 
@@ -1,6 +1,6 @@
1
1
  [metadata]
2
2
  name = pandas-plots
3
- version = 0.11.0
3
+ version = 0.11.2
4
4
  author = smeisegeier
5
5
  author_email = dexterDSDo@googlemail.com
6
6
  description = A collection of helper for table handling and vizualization
@@ -32,6 +32,7 @@ install_requires =
32
32
  seaborn >= 0.13.2
33
33
  Jinja2 >= 3.1.3
34
34
  requests >= 2.31.0
35
+ numpy < 2.0.0
35
36
 
36
37
  [egg_info]
37
38
  tag_build =
@@ -1,6 +1,7 @@
1
1
  import pandas as pd
2
2
  import numpy as np
3
3
  import scipy.stats
4
+ import importlib.metadata as md
4
5
 
5
6
  from io import BytesIO
6
7
  from matplotlib import pyplot as plt
@@ -261,3 +262,24 @@ def add_datetime_columns(df: pd.DataFrame, date_column: str = None) -> pd.DataFr
261
262
  )
262
263
 
263
264
  return df_
265
+
266
+
267
+ def show_package_version(packages: list[str] = ["pandas","numpy","duckdb","pandas-plots", "connection_helper"], sep: str = " | ") -> None:
268
+ """
269
+ Display the versions of the specified packages.
270
+
271
+ Parameters:
272
+ packages (list[str], optional): A list of package names. Defaults to ["pandas","numpy","duckdb","pandas-plots", "connection_helper"].
273
+ sep (str, optional): The separator to use when joining the package names and versions. Defaults to " | ".
274
+
275
+ Returns:
276
+ None
277
+ """
278
+ items = []
279
+ for item in packages:
280
+ try:
281
+ version = md.version(item)
282
+ items.append(f"📦 {item}: {version}")
283
+ except md.PackageNotFoundError:
284
+ items.append(f"❌ {item}: Package not found")
285
+ print(sep.join(items))
@@ -125,7 +125,7 @@ def plot_stacked_bars(
125
125
  Parameters:
126
126
  - df: pd.DataFrame - The DataFrame containing the data to plot.
127
127
  - top_n_index: int = 0 - The number of top indexes to include in the plot.
128
- - top_n_index: int = 0 - The number of top colors to include in the plot. WARNING: this forces distribution to 100% on a subset
128
+ - top_n_color: int = 0 - The number of top colors to include in the plot. WARNING: this forces distribution to 100% on a subset
129
129
  - dropna: bool = False - Whether to include NULL values in the plot.
130
130
  - swap: bool = False - Whether to swap the x-axis and y-axis.
131
131
  - normalize: bool = False - Whether to normalize the values.
@@ -17,6 +17,7 @@ from scipy import stats
17
17
  from .hlp import wrap_text
18
18
 
19
19
  # from devtools import debug
20
+
20
21
  pd.options.display.colheader_justify = "right"
21
22
  # pd.options.mode.chained_assignment = None
22
23
 
@@ -225,6 +226,7 @@ def pivot_df(
225
226
  kpi_shape: Literal["squad", "circle"] = "squad",
226
227
  ) -> pd.DataFrame:
227
228
  """
229
+ DEPR: This function is deprecated and will be removed in the future.
228
230
  A function to pivot a DataFrame based on specified parameters and return the result as a new DataFrame.
229
231
 
230
232
  Args:
@@ -365,6 +367,7 @@ def show_num_df(
365
367
  - max_min_x: max value green, min valued red for x axis
366
368
  - kpi_rag_list: a list of floats indicating the thresholds for rag lights. The list should have 2 elements.
367
369
  - kpi_shape: a Literal indicating the shape of the KPIs ["squad", "circle"]
370
+ - show_as_pct: a boolean indicating whether to show value as percentage (only advised on values ~1)
368
371
 
369
372
  The function returns a styled representation of the DataFrame.
370
373
  """
@@ -472,8 +475,13 @@ def show_num_df(
472
475
  Returns:
473
476
  str: The appropriate icon based on the value and KPI mode.
474
477
  """
478
+
479
+ # * no icon if no mode. (or Total column, but total index cannot be located)
475
480
  if not kpi_mode:
481
+ # if not kpi_mode or col == "Total":
476
482
  return ""
483
+
484
+
477
485
 
478
486
  dict_icons = {
479
487
  "squad": {
@@ -486,7 +494,6 @@ def show_num_df(
486
494
  },
487
495
  }
488
496
  icons = dict_icons[kpi_shape][theme]
489
-
490
497
  # * transform values into percentiles if relative mode
491
498
  kpi_rag_list_ = kpi_rag_list
492
499
  if kpi_mode == "rag_rel":
@@ -517,19 +524,14 @@ def show_num_df(
517
524
  min_ = tbl_min if kpi_mode.endswith("_xy") else col_min[col]
518
525
  max_ = tbl_max if kpi_mode.endswith("_xy") else col_max[col]
519
526
 
520
- # * omit Total column for min/max
521
- if col == "Total":
522
- return ""
523
-
524
527
  # * calculate order of icons
525
528
  if kpi_mode.startswith("min_max"):
526
529
  result = icons[0] if val == min_ else icons[2] if val == max_ else icons[3]
527
530
  elif kpi_mode.startswith("max_min"):
528
531
  result = icons[0] if val == max_ else icons[2] if val == min_ else icons[3]
529
532
  else:
530
- # * no matching mode founf
533
+ # * no matching mode found
531
534
  result = ""
532
-
533
535
  return result
534
536
 
535
537
  # * all cell formatting in one place
@@ -562,7 +564,7 @@ def show_num_df(
562
564
  return f"{val:.{precision}%} {kpi}"
563
565
  return f"{val:_.{precision}f} {kpi}"
564
566
 
565
- # * formatter is now unified, col wise
567
+ # * formatter is a dict comprehension, only accepts column names
566
568
  formatter = {col: lambda x, col=col: format_cell(x, col=col) for col in df_.columns}
567
569
 
568
570
  # ? pct_axis y is not implemented, needs row wise formatting
@@ -572,6 +574,7 @@ def show_num_df(
572
574
  # }
573
575
 
574
576
  # * apply formatter
577
+ # debug(formatter)
575
578
  out.format(formatter=formatter)
576
579
 
577
580
  # * apply fonts for cells
@@ -231,7 +231,6 @@ def show_venn2(
231
231
  a_label: str,
232
232
  b_set: set,
233
233
  b_label: str,
234
- # theme: Literal["light", "dark"] = "dark",
235
234
  max_set_len: int = 100,
236
235
  max_line_width: int = 120,
237
236
  alpha: float = 0.7,
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.1
2
2
  Name: pandas-plots
3
- Version: 0.11.0
3
+ Version: 0.11.2
4
4
  Summary: A collection of helper for table handling and vizualization
5
5
  Home-page: https://github.com/smeisegeier/pandas-plots
6
6
  Author: smeisegeier
@@ -26,10 +26,11 @@ Requires-Dist: matplotlib-venn>=0.11.10
26
26
  Requires-Dist: seaborn>=0.13.2
27
27
  Requires-Dist: Jinja2>=3.1.3
28
28
  Requires-Dist: requests>=2.31.0
29
+ Requires-Dist: numpy<2.0.0
29
30
 
30
31
  # pandas-plots
31
32
 
32
- ![PyPI - Version](https://img.shields.io/pypi/v/pandas-plots) ![GitHub last commit](https://img.shields.io/github/last-commit/smeisegeier/pandas-plots?logo=github) ![GitHub License](https://img.shields.io/github/license/smeisegeier/pandas-plots?logo=github) ![py3.10](https://img.shields.io/badge/python-3.10-blue.svg?logo=)
33
+ ![PyPI - Version](https://img.shields.io/pypi/v/pandas-plots) ![GitHub last commit](https://img.shields.io/github/last-commit/smeisegeier/pandas-plots?logo=github) ![GitHub License](https://img.shields.io/github/license/smeisegeier/pandas-plots?logo=github) ![py3.10](https://img.shields.io/badge/python-3.10_|_3.11_|_3.12-blue.svg?logo=)
33
34
 
34
35
  ## usage
35
36
 
@@ -98,8 +99,9 @@ tbl.show_num_df(
98
99
  - `mean_confidence_interval()` calculates mean and confidence interval for a series
99
100
  - `wrap_text()` formats strings or lists to a given width to fit nicely on the screen
100
101
  - `replace_delimiter_outside_quotes()` when manual import of csv files is needed: replaces delimiters only outside of quotes
101
- - 🆕 `create_barcode_from_url()` creates a barcode from a given URL
102
- - 🆕 `add_datetime_col()` adds a datetime columns to a dataframe
102
+ - `create_barcode_from_url()` creates a barcode from a given URL
103
+ - `add_datetime_col()` adds a datetime columns to a dataframe
104
+ - 🆕 `show_package_version` prints version of a list of packages
103
105
 
104
106
  > note: theme setting can be controlled through all functions by setting the environment variable `THEME` to either light or dark
105
107
 
@@ -5,3 +5,4 @@ matplotlib-venn>=0.11.10
5
5
  seaborn>=0.13.2
6
6
  Jinja2>=3.1.3
7
7
  requests>=2.31.0
8
+ numpy<2.0.0
File without changes