From 782e685ce65ab5703aa76a7f7521d57a1ecc47bc Mon Sep 17 00:00:00 2001 From: "Lumberbot (aka Jack)" <39504233+meeseeksmachine@users.noreply.github.com> Date: Mon, 23 Oct 2023 00:37:15 +0200 Subject: [PATCH] Backport PR #55537 on branch 2.1.x (BUG: Series inferring new string dtype even if dtype is given for scalar value) (#55635) Backport PR #55537: BUG: Series inferring new string dtype even if dtype is given for scalar value Co-authored-by: Patrick Hoefler <61934744+phofl@users.noreply.github.com> --- pandas/core/construction.py | 7 ++++++- pandas/tests/series/test_constructors.py | 8 ++++++++ 2 files changed, 14 insertions(+), 1 deletion(-) diff --git a/pandas/core/construction.py b/pandas/core/construction.py index e661d590ab330..5903187769f08 100644 --- a/pandas/core/construction.py +++ b/pandas/core/construction.py @@ -540,6 +540,7 @@ def sanitize_array( ------- np.ndarray or ExtensionArray """ + original_dtype = dtype if isinstance(data, ma.MaskedArray): data = sanitize_masked_array(data) @@ -562,7 +563,11 @@ def sanitize_array( if not is_list_like(data): if index is None: raise ValueError("index must be specified when data is not list-like") - if isinstance(data, str) and using_pyarrow_string_dtype(): + if ( + isinstance(data, str) + and using_pyarrow_string_dtype() + and original_dtype is None + ): from pandas.core.arrays.string_ import StringDtype dtype = StringDtype("pyarrow_numpy") diff --git a/pandas/tests/series/test_constructors.py b/pandas/tests/series/test_constructors.py index 2c3fdf627788a..8cc891e1ee9c0 100644 --- a/pandas/tests/series/test_constructors.py +++ b/pandas/tests/series/test_constructors.py @@ -2123,6 +2123,14 @@ def test_series_string_inference_storage_definition(self): result = Series(["a", "b"], dtype="string") tm.assert_series_equal(result, expected) + def test_series_constructor_infer_string_scalar(self): + # GH#55537 + with pd.option_context("future.infer_string", True): + ser = Series("a", index=[1, 2], dtype="string[python]") + expected = Series(["a", "a"], index=[1, 2], dtype="string[python]") + tm.assert_series_equal(ser, expected) + assert ser.dtype.storage == "python" + class TestSeriesConstructorIndexCoercion: def test_series_constructor_datetimelike_index_coercion(self):