I 다음 dataframe 있습니다고급 단면
lb = [('A','a',1), ('A','a',2), ('A','a',3), ('A','b',1), ('A','b',2), ('A','b',3), ('B','a',1), ('B','a',2), ('B','a',3), ('B', 'b',1), ('B','b',2) ,('B','b',3)]
col = pd.MultiIndex.from_tuples(lb, names=['first','second','third'])
df = pd.DataFrame(randn(5,12), columns=col)
first A B \
second a b a
third 1 2 3 1 2 3 1
0 1.597958 2.054695 0.449745 -0.990393 0.780978 -0.590558 -0.691706
1 -0.093841 -1.203769 1.779555 -0.299931 -0.411360 0.122852 -0.250156
2 0.025183 0.514480 -0.420666 1.574669 0.962010 1.278237 -0.976286
3 -1.028288 -0.506581 0.880370 1.513487 -0.066479 -0.100231 0.785042
4 -1.635642 0.464074 -0.335941 -0.034194 0.412519 -0.672058 0.113886
first
second b
third 2 3 1 2 3
0 1.954769 0.705860 -1.712058 1.015807 1.245232
1 -2.037299 -0.120649 -0.114652 -0.686707 -0.993540
2 0.918084 -0.892378 -0.741131 -2.547121 0.797637
3 0.000077 2.123063 0.903571 1.972190 -1.179325
4 -1.145241 -1.773182 0.407046 -0.301640 -0.173261
내가 좋아하는 STH, 즉, 2, 3과 모든 열을 가져올를
df.xs([2,3], level='third', axis=1, drop_level=False)
그러나 이 작동하지 않습니다. 어떻게해야합니까?
안녕하세요, 좋은 소식입니다 @ 제프! 슬라이싱 방법을 더 쉽게 만듭니다. 이제이 목표와 관련이 있습니다. 각 멀티 인덱스에 대해 열 1을 열 2,3으로 어떻게 나누겠습니까? – gmask
내가 찾고있는 것과 더 가깝지 만 데이터 프레임에있는 그대로의 열 1을 유지하고 싶습니다. 내 응용 프로그램에서 열 1은 다른 열로 뺀 참조 데이터입니다. 다중 색인은 측정의 다른 '실행'입니다. – gmask
업데이트되었습니다. 동일한 마스크를 사용하여 간단히 설정할 수 있습니다 (역설적으로 이것이 rhs가 훨씬 단순하지 않은 '이유'입니다). – Jeff