Я работаю с питоном. Я пытаюсь создать столбец из единиц и нулей, вы знаете период года.
selected['Period']=np.zeros(len(selected.index))
for i in selected['Week']:
if (25<=i<=47):
selected['Period']=0
elif (48<=i>=24):
selected['Period']=1
Недельные столбцы имеют недельные значения года (int), созданные из функции x.week (из даты и времени) Я пытался расширить условия, попробовать разные формы, но это принимает только нулевое значение, и я не вижу проблемы. Спасибо!
Моя идея состоит в том, чтобы иметь столбец с двоичными значениями и с помощью функции выбрать период года для работы, или [25,47] период, или [48,24]
Чтобы быть более понятным: [0,24] -> 1 ; [25,47] -> 0; [48,52] -> 1.
Обновлено: фрейм данных для цикла
Проверьте свои диапазоны, потому что это не имеет смысла, должно быть 25 <= i <= 47
if (25<=i>=47)
означает if (i >= 25) and (i >= 47):
. Я подозреваю, что это не то, что вы хотите.
В течение недель в диапазоне 25,47 (25,26,.....46, 47) я хочу 0. И в диапазоне 48,24 (48,49....0...23,24) я хочу 1
Вдим? Этот последний комментарий не имеет смысла, потому что эти два диапазона на 99% совпадают.
Вам не хватает минуса, это должно перейти с 25 на минус (-47)????
я исправил <
Мужик, как перейти от 48 к 49 (т.е. увеличить на 1 или добавить 1) к 0????????????????????????????
Моя идея состоит в том, чтобы иметь столбец с двоичными значениями и с помощью функции выбрать период года для работы, или [25,47] период, или [48,24]
Вы, кажется, не понимаете, если вы идете от 48 до 49 до 50, 51, 52, вы не дойдете до 0 ...... 0 меньше 48, что означает, что ваши диапазоны математически не имеют смысла. Они не имеют смысла ни в каком отношении. И снова ваш последний комментарий [25-47] и [24 - 48] Один диапазон полностью находится внутри другого диапазона???? тогда число 30 должно быть 1 или 0???
Чтобы быть более понятным: [0,24] -> 1 ; [25,47] -> 0; [48,52] -> 1.
"чтобы было понятнее" ты хотел сказать "чтобы наконец стало ясно"
Как насчет использования простого else
?
selected['Period'] = np.zeros(len(selected.index))
for i in selected['Week']:
if 25 <=i <= 47:
selected['Period'] = 0
else:
selected['Period'] = 1
Объяснение от OP не имеет смысла. Это наиболее логичное решение, но без серьезного редактирования вопроса мы не узнаем, чего хочет ОП.
С этим кодом все столбцы периода имеют значение «1».
selected['Period']
получит значение, полученное в последней итерации цикла. Если вы хотите что-то другое, вам придется объяснить это в вопросе.
@Matthias Прочитайте комментарии к вопросу.
selected['Period'] = np.zeros(len(selected.index))
for i in selected['Week']:
if 0 <=i <= 24:
selected['Period'] = 1
elif 25 <=i <= 47:
selected['Period'] = 0
elif 48 <=i <= 52:
selected['Period'] = 1
После некоторого обсуждения этого в комментариях я предполагаю, что это то, что вы хотите.
Я ожидал, что это сработает, но нет, он вставил все кол. '1', как вы можете видеть в первом посте (отредактировано)
@aandoni Можете ли вы задать вопрос, как выглядят столбцы, например, показать, каковы значения.
я сделал это с вашими условиями if, но в цикле for добавил индекс и использовал .loc внутри
Ваши диапазоны мне непонятны. например должно быть
47
0 или 1?