diff --git a/python/cudf/cudf/core/column/column.py b/python/cudf/cudf/core/column/column.py index c1ad5de1181..33d845c7a18 100644 --- a/python/cudf/cudf/core/column/column.py +++ b/python/cudf/cudf/core/column/column.py @@ -2452,25 +2452,29 @@ def as_column( def _construct_array( arbitrary: Any, dtype: Optional[Dtype] -) -> Union[np.ndarray, cupy.ndarray]: +) -> Union[np.ndarray, cupy.ndarray, pd.api.extensions.ExtensionArray]: """ - Construct a CuPy or NumPy array from `arbitrary` + Construct a CuPy/NumPy/Pandas array from `arbitrary` """ try: dtype = dtype if dtype is None else cudf.dtype(dtype) arbitrary = cupy.asarray(arbitrary, dtype=dtype) except (TypeError, ValueError): native_dtype = dtype + inferred_dtype = None if ( dtype is None and not cudf._lib.scalar._is_null_host_scalar(arbitrary) - and infer_dtype(arbitrary, skipna=False) + and (inferred_dtype := infer_dtype(arbitrary, skipna=False)) in ( "mixed", "mixed-integer", ) ): native_dtype = "object" + if inferred_dtype == "interval": + # Only way to construct an Interval column. + return pd.array(arbitrary) arbitrary = np.asarray( arbitrary, dtype=native_dtype diff --git a/python/cudf/cudf/tests/test_interval.py b/python/cudf/cudf/tests/test_interval.py index e1104829914..93b831a92c9 100644 --- a/python/cudf/cudf/tests/test_interval.py +++ b/python/cudf/cudf/tests/test_interval.py @@ -1,6 +1,7 @@ -# Copyright (c) 2020-2022, NVIDIA CORPORATION. +# Copyright (c) 2020-2023, NVIDIA CORPORATION. import pandas as pd +import numpy as np import pytest import cudf @@ -132,3 +133,15 @@ def test_create_interval_df(data1, data2, data3, data4, closed): dtype="interval", ) assert_eq(expect_three, got_three) + + +def test_create_interval_index_from_list(): + interval_list = [ + np.nan, + pd.Interval(2.0, 3.0, closed="right"), + pd.Interval(3.0, 4.0, closed="right"), + ] + expected = pd.Index(interval_list) + actual = cudf.Index(interval_list) + + assert_eq(expected, actual)