Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

docs: add third party pandas.Index methods and docstrings #1171

Merged
merged 13 commits into from
Nov 27, 2024
Merged
11 changes: 0 additions & 11 deletions bigframes/core/indexes/base.py
Original file line number Diff line number Diff line change
Expand Up @@ -175,7 +175,6 @@ def dtypes(self) -> pandas.Series:

@property
def size(self) -> int:
"""Returns the size of the Index."""
return self.shape[0]

@property
Expand All @@ -186,12 +185,7 @@ def empty(self) -> bool:
@property
@validations.requires_ordering()
def is_monotonic_increasing(self) -> bool:
"""
Return a boolean if the values are equal or increasing.

Returns:
bool
"""
return typing.cast(
bool,
self._block.is_monotonic_increasing(self._block.index_columns),
Expand All @@ -200,12 +194,7 @@ def is_monotonic_increasing(self) -> bool:
@property
@validations.requires_ordering()
def is_monotonic_decreasing(self) -> bool:
"""
Return a boolean if the values are equal or decreasing.

Returns:
bool
"""
return typing.cast(
bool,
self._block.is_monotonic_decreasing(self._block.index_columns),
Expand Down
169 changes: 167 additions & 2 deletions third_party/bigframes_vendored/pandas/core/indexes/base.py
Original file line number Diff line number Diff line change
Expand Up @@ -25,15 +25,180 @@ class Index:
"""

@property
def name(self):
"""Returns Index name."""
def names(self):
arwas11 marked this conversation as resolved.
Show resolved Hide resolved
"""Returns the names of the Index.

Returns:
Sequence[blocks.Label]:
A Sequence of Index or MultiIndex name
"""
raise NotImplementedError(constants.ABSTRACT_METHOD_ERROR_MESSAGE)

@property
def values(self):
"""Return an array representing the data in the Index."""
raise NotImplementedError(constants.ABSTRACT_METHOD_ERROR_MESSAGE)

@property
def ndim(self):
"""
Number of dimensions of the underlying data, by definition 1.

**Examples:**

>>> import bigframes.pandas as bpd
>>> bpd.options.display.progress_bar = None

>>> s = bpd.Series(['Ant', 'Bear', 'Cow'])
>>> s
0 Ant
1 Bear
2 Cow
dtype: string

>>> s.ndim
1

For Index:

>>> idx = bpd.Index([1, 2, 3])
>>> idx
Index([1, 2, 3], dtype='Int64')

>>> idx.ndim
1

Returns:
int:
Number or dimensions.
"""
raise NotImplementedError(constants.ABSTRACT_METHOD_ERROR_MESSAGE)

@property
def size(self) -> int:
"""
Return the number of elements in the underlying data.

**Examples:**

>>> import bigframes.pandas as bpd
>>> bpd.options.display.progress_bar = None

For Series:

>>> s = bpd.Series(['Ant', 'Bear', 'Cow'])
>>> s
0 Ant
1 Bear
2 Cow
dtype: string

For Index:

>>> idx = bpd.Index([1, 2, 3])
>>> idx
Index([1, 2, 3], dtype='Int64')

Returns:
int:
Number of elements
"""
raise NotImplementedError(constants.ABSTRACT_METHOD_ERROR_MESSAGE)

@property
def empty(self) -> bool:
raise NotImplementedError(constants.ABSTRACT_METHOD_ERROR_MESSAGE)

@property
def is_monotonic_increasing(self) -> bool:
"""
Return a boolean if the values are equal or increasing.

**Examples:**

>>> import bigframes.pandas as bpd
>>> bpd.options.display.progress_bar = None

>>> bool(bpd.Index([1, 2, 3]).is_monotonic_increasing)
True

>>> bool(bpd.Index([1, 2, 2]).is_monotonic_increasing)
True

>>> bool(bpd.Index([1, 3, 2]).is_monotonic_increasing)
False

Returns:
bool:
True, if the values monotonically increasing, otherwise False.
"""
raise NotImplementedError(constants.ABSTRACT_METHOD_ERROR_MESSAGE)

@property
def is_monotonic_decreasing(self) -> bool:
"""
Return a boolean if the values are equal or decreasing.

**Examples:**

>>> import bigframes.pandas as bpd
>>> bpd.options.display.progress_bar = None

>>> bool(bpd.Index([3, 2, 1]).is_monotonic_decreasing)
True

>>> bool(bpd.Index([3, 2, 2]).is_monotonic_decreasing)
True

>>> bool(bpd.Index([3, 1, 2]).is_monotonic_decreasing)
False

Returns:
bool:
True, if the values monotonically decreasing, otherwise False.
"""
raise NotImplementedError(constants.ABSTRACT_METHOD_ERROR_MESSAGE)

@classmethod
def from_frame(cls, frame) -> Index:
"""
Make a MultiIndex from a DataFrame.

**Examples:**

>>> import bigframes.pandas as bpd
>>> bpd.options.display.progress_bar = None

>>> df = bpd.DataFrame([['HI', 'Temp'], ['HI', 'Precip'],
... ['NJ', 'Temp'], ['NJ', 'Precip']],
... columns=['a', 'b'])
>>> df
a b
0 HI Temp
1 HI Precip
2 NJ Temp
3 NJ Precip
<BLANKLINE>
[4 rows x 2 columns]

>>> bpd.MultiIndex.from_frame(df)
Index([0, 1, 2, 3], dtype='Int64')

Args:
frame (Union[bigframes.pandas.Series, bigframes.pandas.DataFrame]):
bigframes.pandas.Series or bigframes.pandas.DataFrame to convert
to bigframes.pandas.Index.

Returns:
bigframes.pandas.Index:
The Index representation of the given Series or DataFrame.

Raises:
bigframes.exceptions.NullIndexError:
If Index is Null.
"""
raise NotImplementedError(constants.ABSTRACT_METHOD_ERROR_MESSAGE)

@property
def shape(self):
"""
Expand Down