|
38 | 38 | from pandas.tests.frame.common import TestData
|
39 | 39 |
|
40 | 40 |
|
| 41 | +@pytest.fixture(scope='module', |
| 42 | + params=['dataframe', 'ndarray']) |
| 43 | +def f_get_mask(request): |
| 44 | + from functools import partial |
| 45 | + |
| 46 | + def get_mask(df, mask_type): |
| 47 | + if mask_type == 'dataframe': |
| 48 | + return df > np.abs(df) |
| 49 | + elif mask_type == 'ndarray': |
| 50 | + return (df > np.abs(df)).values |
| 51 | + else: |
| 52 | + raise ValueError("Unknown `mask_type` '{}'".format(mask_type)) |
| 53 | + |
| 54 | + return partial(get_mask, mask_type=request.param) |
| 55 | + |
| 56 | + |
41 | 57 | class TestDataFrameIndexing(TestData):
|
42 | 58 |
|
43 | 59 | def test_getitem(self):
|
@@ -541,22 +557,21 @@ def test_setitem_boolean(self):
|
541 | 557 | np.putmask(expected.values, mask.values, df.values * 2)
|
542 | 558 | assert_frame_equal(df, expected)
|
543 | 559 |
|
544 |
| - def test_setitem_boolean_ndarary(self): |
| 560 | + def test_setitem_boolean_mask(self, f_get_mask): |
545 | 561 | # Test for issue #18582
|
546 |
| - |
547 | 562 | df = self.frame.copy()
|
548 |
| - mask = df > np.abs(df) |
549 |
| - expected = df.copy() |
550 |
| - expected.values[mask.values] = nan |
551 |
| - |
552 |
| - # index with 2-d boolean ndarray |
553 |
| - actual = df.copy() |
554 |
| - actual[mask.values] = nan |
555 |
| - assert_frame_equal(actual, expected) |
556 |
| - |
557 |
| - # index with boolean DataFrame |
| 563 | + mask = f_get_mask(df) |
| 564 | + |
| 565 | + # index with boolean mask |
558 | 566 | actual = df.copy()
|
559 | 567 | actual[mask] = nan
|
| 568 | + |
| 569 | + # compare against ndarray boolean indexing |
| 570 | + if isinstance(mask, pd.DataFrame): |
| 571 | + mask = mask.values |
| 572 | + |
| 573 | + expected = df.copy() |
| 574 | + expected.values[mask] = nan |
560 | 575 | assert_frame_equal(actual, expected)
|
561 | 576 |
|
562 | 577 | def test_setitem_cast(self):
|
|
0 commit comments