-
-
Notifications
You must be signed in to change notification settings - Fork 18.1k
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
Fixes SparseSeries initiated with dictionary raising AttributeError #16960
Changes from 1 commit
b05ba81
6877159
19da337
9869a05
2d3e318
4ce5703
5a4605a
5416762
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 |
---|---|---|
|
@@ -146,10 +146,10 @@ def __init__(self, data=None, index=None, sparse_index=None, kind='block', | |
data = data._data | ||
|
||
elif isinstance(data, (Series, dict)): | ||
data = Series(data) | ||
if index is None: | ||
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. hmm, I think you might be able to remove this 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. see what if anything breaks 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. I ran the full test suite with this change and everything is working. I also manually ran a bunch of SparseSeries with different inputs (Series, dicts, with/without indexes) and it does work as intended. |
||
index = data.index.view() | ||
|
||
data = Series(data) | ||
res = make_sparse(data, kind=kind, fill_value=fill_value) | ||
data, sparse_index, fill_value = res | ||
|
||
|
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -87,6 +87,12 @@ def setup_method(self, method): | |
fill_value=0) | ||
self.ziseries2 = SparseSeries(arr, index=index, kind='integer', | ||
fill_value=0) | ||
def test_constructor_data_input(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. Rename to |
||
arr = SparseSeries({1: 1}) | ||
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 reference the issue right above this line (e.g. "# see gh-16905)"? 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. Notice how you use |
||
assert arr.count() == len({1: 1}) | ||
|
||
arr = SparseSeries(pd.Series({1: 1}, index=[0, 1, 2])) | ||
assert arr.count() == pd.Series({1: 1}, index=[0, 1, 2]).count() | ||
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. I would separate out your |
||
|
||
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. Okay : in light of what you just said, I think you can condense this test a bit and rename as follows: def test_constructor_dict_input(self):
...
series = pd.Series(constructor_dict, index=index)
expected = SparseSeries(series, index=index)
result = SparseSeries(constructor_dict)
tm.assert_sp_series_equal(result, expected) And delete everything else below it. 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. Thanks for this. I added this test and did find a case that was not handled correctly. I fixed the code and added tests for all options of SparseSeries creation. |
||
def test_constructor_dtype(self): | ||
arr = SparseSeries([np.nan, 1, 2, np.nan]) | ||
|
@@ -109,6 +115,9 @@ def test_constructor_dtype(self): | |
assert arr.dtype == np.int64 | ||
assert arr.fill_value == 0 | ||
|
||
arr = SparseSeries({1: 1}) | ||
assert arr.dtype == np.int64 | ||
|
||
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. On second look, I don't think you need this. You can remove. |
||
def test_iteration_and_str(self): | ||
[x for x in self.bseries] | ||
str(self.bseries) | ||
|
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.
dicitonary --> dictionary
"passed as" --> "passed in as"