-
-
Notifications
You must be signed in to change notification settings - Fork 18.2k
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
BUG: RecursionError when attempting to replace np.nan
values under main branch
#45725
Comments
From my testing and debugging, I think this regression is caused from PR #45304 (merged to main branch with the 1.5 milestone), specifically the change in the |
solution is to add |
Alright working on a PR with Fix+Tests now. |
np.nan
values under main branch
hmm, bisect is giving first bad commit: [eae37b0] BUG: Series[Interval[int]][1] = np.nan incorrect coercion/raising (#45568) |
can confirm that the regression reported here is the result of the following code added to elif is_valid_na_for_dtype(right, left.dtype):
# e.g. IntervalDtype[int] and None/np.nan
new_dtype = ensure_dtype_can_hold_na(left.dtype) |
what are right and left.dtype in the relevant cases? |
ignoring the in Block.replace
so we know that we need to enter the
block once the blocks have been split and change the dtype of the block so that
the call to
and we set
instead of returning object
|
Yikes, there are a couple of unpleasant things interacting here. In many Block methods we do The alternative is to intercept this particular situation somewhere. I think @simonjayhawkins has a branch that intercepts it at the level of find_common_type, but unless there are other use cases I'm inclined to handle it in Block.replace (though he likely has thought about it more than i have). There's also an alternative where we do |
* [WIP] Pandas 1.5 support * Partial progress * Exclude pandas 1.5.0 and 1.5.1 because of pandas-dev/pandas#45725 * Plumb group_keys more places * Fix bad argument * Fix bad argument * Debug * Debug * Debug * Debug * allow list tests * Update changes * fmt * Lint * Lint * Fix pd_version * Fix pd_version * Remove CHANGES.md since this needs to go in 2.45 section
Pandas version checks
I have checked that this issue has not already been reported.
I have confirmed this bug exists on the latest version of pandas.
I have confirmed this bug exists on the main branch of pandas.
Reproducible Example
Issue Description
Note: this bug is not present in 1.4.x branch, but it is in the main branch and 1.5 milestone.
Let's say we have a Series or DataFrame containing
numpy.nan
values (a common scenario), and we want to convert them all to Panda's own typepandas.NA
, or alternatively to the native PythonNone
type. One way to do this conversion is by using thereplace
method as shown in the example. From my testing this works in pandas 1.4.0 as well as 1.3.5, but not in the main branch. A RecursionError exception is thrown.Suggested tags:
1.5 Milestone
,Regression
,replace
,Dtype Conversions
Expected Behavior
The
replace
method should successfully replacenp.nan
with the desired value, without errors. This behavior works in pandas 1.4.0 and previous versions and should be fixed for the pandas 1.5 release.Installed Versions
python : 3.10.2.final.0
python-bits : 64
OS : Windows
OS-release : 10
Version : 10.0.22000
machine : AMD64
processor : Intel64 Family 6 Model 158 Stepping 10, GenuineIntel
byteorder : little
LC_ALL : None
LANG : None
LOCALE : English_United States.1252
pandas : 1.5.0.dev0+234.gf77480f9f5
numpy : 1.22.1
pytz : 2021.3
dateutil : 2.8.2
pip : 21.1.2
setuptools : 57.0.0
Cython : None
pytest : None
hypothesis : None
sphinx : None
blosc : None
feather : None
xlsxwriter : None
lxml.etree : None
html5lib : None
pymysql : None
psycopg2 : None
jinja2 : None
IPython : None
pandas_datareader: None
bs4 : None
bottleneck : None
fastparquet : None
fsspec : None
gcsfs : None
matplotlib : None
numba : None
numexpr : None
odfpy : None
openpyxl : None
pandas_gbq : None
pyarrow : None
pyreadstat : None
pyxlsb : None
s3fs : None
scipy : None
sqlalchemy : None
tables : None
tabulate : None
xarray : None
xlrd : None
xlwt : None
zstandard : None
The text was updated successfully, but these errors were encountered: