Объединение повторяющихся столбцов в панде

Вы не первый, кто попал в знаменитую «задержанную ловушку расширения» (и вы не станете последним)

Вам нужно задержать расширение, если вы хотите использовать переменную, что вы изменен в том же блоке (блок представляет собой последовательность команд в скобках ( и ))

Отложенные переменные ссылаются на !var! вместо %var%

Причина в том, что cmd анализирует код. Полная строка или блок анализируется сразу, заменяя обычные переменные своим значением во время разбора. Отложенные переменные оцениваются во время выполнения.

Две простые партии для демонстрации:

setlocal enabledelayedexpansion
set "var=hello"
if 1==1 (
  set "var=world"
  echo %var% !var!
)

.

setlocal enabledelayedexpansion
for /L %%i in (1,1,5) do (
  echo %random% !random!
)

Примечание: также строка рассматривается как block:

set "var=old"
set "var=new" & echo %var% 

с задержкой расширения:

setlocal enabledelayedexpansion
set "var=old"
set "var=new" & echo !var! 

Отсроченное расширение по умолчанию отключено в командной строке. Если вам это действительно нужно, вы можете сделать:

cmd /v:on /c "set "var=hello" & echo !var!"

Также есть способ сделать то же самое без задержки расширения (но call стоит некоторое время, поэтому он медленнее, но если по какой-то причине вы не можете / не хотите использовать замедленное расширение, это альтернатива):

setlocal DISabledelayedexpansion
for /L %%i in (1,1,5) do (
  call echo %random% %%random%% 
)

Оба метода могут использоваться для отображения переменных типа массива :

setlocal ENabledelayedexpansion
set "num=4"
set "var[%num%]=hello"
echo !var[%num%]!

или

setlocal DISabledelayedexpansion
set "num=4"
set "var[%num%]=hello"
call echo %%var[%num%]%%

(этого часто задают как «переменная, которая содержит другую переменную» или «вложенные переменные»

1
задан AGH_TORN 21 March 2019 в 16:57
поделиться

2 ответа

Используя groupby с first, также убедитесь, что ваш бланк равен np.nan, если нет, replace он

#df=df.replace({'':'np.nan}) or df=df.mask(df=='')
df.groupby(level=0,axis=1).first()
0
ответ дан Wen-Ben 21 March 2019 в 16:57
поделиться

Если пустая строка пуста, сумма будет работать

0
ответ дан Vaishali 21 March 2019 в 16:57
поделиться
Другие вопросы по тегам:

Похожие вопросы: