Мой пример использует для получения данных из строк с различными значениями для столбцов C и D и создания новых данных для них.Затем добавьте эти новые данные к данным без различий.
import pandas as pd
# setup data
data_raw = [['AA', 111, 2, 2], ['CC', 222, 8, 12], ['DD', 333, 3, 3]]
data = pd.DataFrame(data_raw, columns=['A', 'B', 'C','D'])
# get items with no difference
rest_of_data = data.loc[data['C'] == data['D']]
# create value for E column
rest_of_data = rest_of_data.copy()
rest_of_data['E'] = str(str(rest_of_data['B'].values[0]) + '-' + str(rest_of_data['C'].values[0]))
# find items with difference
difference_data = data.loc[data['C'] != data['D']]
# get numbers of elements to create
start = int(difference_data['C'])
stop = int(difference_data['D'])
# create new data
create_data = []
for i in range(start,stop+1,1):
new = [difference_data['A'].values[0], difference_data['B'].values[0], i, i, str(difference_data['B'].values[0])+'-'+str(i)]
create_data.append(new)
new_data = pd.DataFrame(create_data, columns=['A', 'B', 'C','D', 'E'])
# concatenate frames
frames = [rest_of_data, new_data]
result = pd.concat(frames, ignore_index=True)
Результат:
A B C D E
0 AA 111 2 2 111-2
1 DD 333 3 3 111-2
2 CC 222 8 8 222-8
3 CC 222 9 9 222-9
4 CC 222 10 10 222-10
5 CC 222 11 11 222-11
6 CC 222 12 12 222-12