-
-
Notifications
You must be signed in to change notification settings - Fork 18.4k
Added FrozenList subtraction #15506
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
Added FrozenList subtraction #15506
Changes from 4 commits
ada7cda
f6381a8
cd73faa
2fad2f7
fdcfbbb
2e43849
cb95089
2ab85cb
6a2b48d
fee7a7d
73564ab
0fc7e19
79dd958
0ea8d21
cd7de26
ccd75c7
3d6cee5
66b3b91
6f6c140
8dbde1e
84ba405
428a1b3
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -126,6 +126,14 @@ We could naturally group by either the ``A`` or ``B`` columns or both: | |
grouped = df.groupby('A') | ||
grouped = df.groupby(['A', 'B']) | ||
|
||
If we also have a MultiIndex on columns ``A`` and ``B``, we can group by all | ||
but the specified columns | ||
|
||
.. ipython:: python | ||
|
||
df.set_index(['A', 'B']) | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. this won't work as it returns a new object, instead something like
|
||
grouped = df.groupby(level=df.index.names - ['B']) | ||
|
||
These will split the DataFrame on its index (rows). We could also split by the | ||
columns: | ||
|
||
|
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -26,6 +26,8 @@ Check the :ref:`API Changes <whatsnew_0200.api_breaking>` and :ref:`deprecations | |
New features | ||
~~~~~~~~~~~~ | ||
|
||
- Added difference from FrozenLists (:issue:`15475`) | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more.
|
||
|
||
- Integration with the ``feather-format``, including a new top-level ``pd.read_feather()`` and ``DataFrame.to_feather()`` method, see :ref:`here <io.feather>`. | ||
- ``.str.replace`` now accepts a callable, as replacement, which is passed to ``re.sub`` (:issue:`15055`) | ||
|
||
|
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -31,6 +31,13 @@ def __add__(self, other): | |
|
||
__iadd__ = __add__ | ||
|
||
def __sub__(self, other): | ||
other = set(other) | ||
temp = [x for x in self if x not in other] | ||
return self.__class__(temp) | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. add isub as well (and a test) |
||
|
||
__isub__ = __sub__ | ||
|
||
# Python 2 compat | ||
def __getslice__(self, i, j): | ||
return self.__class__(super(FrozenList, self).__getslice__(i, j)) | ||
|
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -23,13 +23,30 @@ def test_add(self): | |
expected = FrozenList([1, 2, 3] + self.lst) | ||
self.check_result(result, expected) | ||
|
||
def test_sub(self): | ||
result = self.container - [2] | ||
expected = FrozenList([1, 3, 4, 5]) | ||
self.check_result(result, expected) | ||
|
||
def test_sub_dupe(self): | ||
result = FrozenList([1, 2, 3, 2]) - [2] | ||
expected = FrozenList([1, 3]) | ||
self.check_result(result, expected) | ||
|
||
def test_inplace(self): | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. can you rename this to make consistent |
||
q = r = self.container | ||
q += [5] | ||
self.check_result(q, self.lst + [5]) | ||
# other shouldn't be mutated | ||
self.check_result(r, self.lst) | ||
|
||
def test_inplace_sub(self): | ||
q = r = self.container | ||
q -= [5] | ||
self.check_result(q, self.container - [5]) | ||
# other shouldn't be mutated | ||
self.check_result(r, self.lst) | ||
|
||
|
||
class TestFrozenNDArray(CheckImmutable, CheckStringMixin, tm.TestCase): | ||
mutable_methods = ('put', 'itemset', 'fill') | ||
|
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
add a versionadded tag here