Sou novo em Julia e Julia DataFrames. Meu entendimento é que DataFrames não suportam MultiIndexing, o que geralmente não apresenta muitos problemas, mas traduzir alguns hábitos pythonic para Julia apresenta dificuldades. Gostaria de saber como alguém poderia carregar e subselecionar recursos por colunas, como no exemplo abaixo.
import numpy as np
import pandas as pd
#generating sample data
nsmpls = 10
smpls = [f'smpl{j}' for j in range(nsmpls)]
nfeats = 5
feats = [f'feat{j}' for j in range(nfeats)]
data = np.random.rand(nfeats, nsmpls)
countries = ['France'] * 2 + ['UK'] * 3 + ['US'] * 5
df = pd.DataFrame(data, index=feats, columns=pd.MultiIndex.from_tuples(zip(countries, smpls)))
df.to_csv('./data.tsv', sep='\t')
#---------------------------------------------------------------------
#loading dataset
df = pd.read_csv('./data.tsv', sep='\t', index_col=0, header=[0,1])
#extracting subset
dg = df.xs('France', level=0, axis=1)
print(dg.shape)
#iterating
for country, group in df.groupby(level=0, axis=1):
print('#samples: {}'.format(group.shape[1]))
Algo assim?
Por padrão, o DataFrames adiciona números a nomes de colunas semelhantes, como: França, França_1 etc., então selecionei todas as colunas que continham "França".