From d5bba3b6bf10d0e5793ec69d1e8de0a318cadc2b Mon Sep 17 00:00:00 2001 From: hkoertge Date: Mon, 1 Jul 2024 08:15:09 +0200 Subject: [PATCH] added check to grid_modification.py for verifying that a DataFrame is present in net before accessing its index. closes issue #2321 --- CHANGELOG.rst | 1 + pandapower/toolbox/grid_modification.py | 11 ++++++++--- 2 files changed, 9 insertions(+), 3 deletions(-) diff --git a/CHANGELOG.rst b/CHANGELOG.rst index d8f339cd8..3020fdcc6 100644 --- a/CHANGELOG.rst +++ b/CHANGELOG.rst @@ -37,6 +37,7 @@ Change Log - [FIXED] PowerFactory converter: fix trafo3w tap dependent impedance - [ADDED] PowerFactory converter: support load types (constI, constZ) and the setting whether to consider voltage dependency of loads - [FIXED] deprecation of matplotlib.cm.get_cmap(name) -> matplotlib.colormaps[name] +- [FIXED] merge_nets failing if net2 has custom DataFrame that is not present in net1 [2.14.7] - 2024-06-14 ------------------------------- diff --git a/pandapower/toolbox/grid_modification.py b/pandapower/toolbox/grid_modification.py index 21476ca87..0ebce168f 100644 --- a/pandapower/toolbox/grid_modification.py +++ b/pandapower/toolbox/grid_modification.py @@ -224,6 +224,8 @@ def _merge_nets(net1, net2, validate=True, merge_results=True, tol=1e-9, # reindex net2 elements if some indices already exist in net reindex_lookup = dict() for elm_type in elm_types: + if elm_type not in net: + continue is_dupl = pd.Series(net2[elm_type].index).isin(net[elm_type].index) if any(is_dupl): start = max(net1[elm_type].index.max(), net2[elm_type].index[~is_dupl].max()) + 1 @@ -240,9 +242,12 @@ def _merge_nets(net1, net2, validate=True, merge_results=True, tol=1e-9, # copy dataframes from net2 to net (output) for elm_type in elm_types: - dtypes = net[elm_type].dtypes - net[elm_type] = pd.concat([net[elm_type], net2[elm_type]]) - _preserve_dtypes(net[elm_type], dtypes) + if elm_type in net: + dtypes = net[elm_type].dtypes + net[elm_type] = pd.concat([net[elm_type], net2[elm_type]]) + _preserve_dtypes(net[elm_type], dtypes) + else: + net[elm_type] = net2[elm_type].copy() # copy standard types of net by data of net2 for type_ in net.std_types.keys():