Python Конкатенация и сортировка 3 кадров - PullRequest
1 голос
/ 19 февраля 2020

Я делаю concat на трех фреймах данных, делая код следующим образом:

df_bigram = pd.concat([bigramFreqTable, skipgram, df2],axis=1)
df_bigram

И вывод df_bigram -

                      bigramf   freq           Skipgram   Freq                         bigram          PMI
0  (Asam, deoksiribonukleat,)      1      (unting, DNA)    22                        (12, Å.)    11.487338
1 (deoksiribonukleat,, lebih)      1      (DNA, unting)    22                        (22, Å,)    11.487338
2            (lebih, dikenal)      1        (DNA, yang)    20                     (220, juta)    11.487338
3           (dikenal, dengan)      2        (yang, DNA)    20                 (34, ÅngströmÅ)    11.487338
4         (dengan, singkatan)      1       (DNA, dalam)    13                (A-DNA,, B-DNA,)    11.487338
5            (singkatan, DNA)      1       (dalam, DNA)    13   (Akibatnya,, protein-protein)    11.487338
6                    (DNA, ,)      2   (pasangan, basa)    11                (Alec, Jeffreys)    11.487338
7                 (,, adalah)      1   (basa, pasangan)    11        (Alfred, HersheyHershey)    11.487338
8           (adalah, sejenis)      1    (terdiri, dari)    10      (Asam, deoksiribonukleat,)    11.487338
9       (sejenis, biomolekul)      1    (dari, terdiri)    10            (Bacillus, subtilis)    11.487338
10         (biomolekul, yang)      1        (pada, DNA)    10            (Banyak, yurisdiksi)    11.487338
...            ...                ...          ...         ...               ...                  ...

Проблема в том, что я хочу отсортировать 'freq' по убыванию значения. Я просто запутался, почему другие имена столбцов, такие как Freq и PMI, отсортированы по убыванию, а freq - нет. Итак, я кодирую это для сортировки:

x = df_bigram.sort_values(by='freq', ascending=False)
x

И вывод будет таким:

                bigramf   freq             Skipgram   Freq                      bigram          PMI
72        (unting, DNA)    17    (hidrogen, ikatan)     5     (ditranskripsikan., Para)    11.487338
212         (DNA, yang)    15          (satu, pada)     3           (Temperatur, lebur)    10.487338
136    (pasangan, basa)    10          (dalam, ===)     4              (myeloid, akut.)    11.487338
83      (yang, disebut)     9      (rantai, Proses)     5             (gen., Sedangkan)    11.487338
432  (disebut, sebagai)     9     (unting, disebut)     2           (sama., Karenanya,)     9.902375
58      (terdiri, dari)     9       (DNA, memiliki)     6             (darah,, sperma,)    11.487338
525          (Hal, ini)     8       (disebut, satu)     2          (resisten, terhadap)     9.487338
888     (heliks, ganda)     7    (tergulung, lebih)     2         (banyak, kemungkinan)     7.902375
657       (rantai, DNA)     7      (Diplonema, dan)     2                (sebuah, cara)     8.902375
...          ...           ...            ...          ...                 ...                ...

, в то время как на самом деле я хочу отсортировать все имена столбцов как 'freq', Freq, PMI по убыванию Что я делаю не так?

Ответы [ 2 ]

0 голосов
/ 19 февраля 2020

Я думаю, что это можно исправить, переиндексировав исходные столбцы данных следующим образом:

df_bigram = df_bigram.reindex_axis (bigramFreqTable.columns, axis = 1)

Если вы хотите отсортировать по одному столбцу, то, что вы реализовали выше, правильно. Но если вы хотите отсортировать по нескольким столбцам, вы можете попробовать:

x = df_bigram.sort_values ​​(by = ['freq', 'Freq', 'PMI'], ascending = False)

x

Примечание: - при сортировке по нескольким столбцам pandas sort_value () использует первую переменную, первую и вторую переменную затем.

0 голосов
/ 19 февраля 2020

Проблема в том, что если сортировка в последнем объединенном столбце невозможна, сортировка производится только по парам bigram s столбцов и freq, возможное решение - сначала сортировка, и в основном создается индекс по умолчанию DataFrame.reset_index с drop=True:

df1 = bigramFreqTable.sort_values(by='freq', ascending=False).reset_index(drop=True)
df2 = skipgram.sort_values(by='Freq', ascending=False).reset_index(drop=True)
df3 = df2.sort_values(by='PMI', ascending=False).reset_index(drop=True)

df_bigram = pd.concat([df1, df2, df3],axis=1)
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...