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

QST:bug or not? silent fail of df.iloc[].loc[] = newDataType #37333

Closed
matt32106 opened this issue Oct 22, 2020 · 2 comments
Closed

QST:bug or not? silent fail of df.iloc[].loc[] = newDataType #37333

matt32106 opened this issue Oct 22, 2020 · 2 comments
Labels
Bug Copy / view semantics Warnings Warnings that appear or should be added to pandas

Comments

@matt32106
Copy link

matt32106 commented Oct 22, 2020

If I use a loc chained to a iloc I can change a value if it is of the same dtype:

df = pd.DataFrame([[0, 2, 3], [0, 4, 1], [10, 20, 30]],
...                   index=[4, 5, 6], columns=['A', 'B', 'C'])
df.iloc[1].loc["B"] = 999
df
    A    B   C
4   0    2   3
5   0  999   1
6  10   20  30

This changes the value to 999.
However, this does not work and fails silently if the dtype is different:

df.iloc[1].loc["B"] = "888"
df
    A    B   C
4   0    2   3
5   0  999   1
6  10   20  30

The value is not changed and there is no error raised.
This seems not consistent with the behavior of doing this:

df.iloc[1,1] = "888"
df
    A    B   C
4   0    2   3
5   0  888   1
6  10   20  30

the last code above changes the type of the column silently.

df.dtypes
A     int64
B    object
C     int64

Envirnt:

Python 3.8.5
pd.__version__ : '1.1.3'

I am only a beginner in pandas so I am wondering if this should be reported as a bug or requesting a feature request or if this behavior is normal.

@matt32106 matt32106 added Needs Triage Issue that has not been reviewed by a pandas team member Usage Question labels Oct 22, 2020
@mzeitlin11
Copy link
Member

Please take a look at the Why does assignment fail when using chained indexing? section of https://pandas.pydata.org/docs/user_guide/indexing.html#indexing-view-versus-copy for an in-depth explanation of what's going on here.

Since there are no guarantees about when a view or copy is returned from the step which sets the value, inconsistent behavior like this is expected. In this case, likely the dtype change forces a copy, so the original df is not modified.

However, I would expect

df.iloc[1].loc["B"] = "888"

to give a SettingWithCopy warning, which I am not seeing in master.

@mzeitlin11 mzeitlin11 added the Warnings Warnings that appear or should be added to pandas label Dec 23, 2020
@mzeitlin11 mzeitlin11 added Copy / view semantics and removed Needs Triage Issue that has not been reviewed by a pandas team member labels Jul 1, 2021
@mroeschke
Copy link
Member

I think with the removal of SettingWithCopyWarning and the enforcment of pdep 6 assignment of a value that doesn't fit the existing dtype here should raise so closing

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
Bug Copy / view semantics Warnings Warnings that appear or should be added to pandas
Projects
None yet
Development

No branches or pull requests

3 participants