Форум программистов, компьютерный форум, киберфорум
Python для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.94/47: Рейтинг темы: голосов - 47, средняя оценка - 4.94
 Аватар для VistaSV30
986 / 330 / 79
Регистрация: 10.04.2012
Сообщений: 1,239
Записей в блоге: 4

Поменять местами строки фрейма

27.02.2021, 16:37. Показов 9426. Ответов 2

Студворк — интернет-сервис помощи студентам
Добрый день!

Как поменять местами строки во фрейме?
Python
1
2
3
4
5
6
7
8
9
import numpy as np
import pandas as pd
import itertools as it # функции комбинаторики
 
# создание массива
np.random.seed(1000)
df = pd.DataFrame(np.random.randint(10, 99, (6, 8))) # создание фрейма
df[0] = [i[0]+i[1] for i in it.permutations('ABC', 2)] # строковые значения для первой колонки
df.columns = ['Name', 'c1', 'c2', 'c3', 'c4', 'c5', 'c6', 'c7'] # назначить имена колонок
Так пробовал - не получилось
Python
1
2
a, b = df[df.Name == 'BC'], df[df.Name == 'CB']
df[df.Name == 'BC'], df[df.Name == 'CB'] = b, a
Спасибо!

Добавлено через 16 минут
Можно назначить новые индексы и выполнить сортировку
Python
1
2
d = {5: 2, 5: 2}
df = df.rename(d).sort_index()
Но мне нужно сделать так, чтобы ключи и значения в словаре можно было назначать с помощью переменной
Python
1
2
3
4
# примерно так
a = int(df[df.Name == 'BA'].index)
d = {5: a, a: 5}
df = df.rename(d).sort_index()
Добавлено через 1 час 34 минуты
Можно поменять значения индексов и потом отсортировать по индексам
Python
1
2
3
4
5
6
a = 1 #df[df.Name == 'AC'].index
name_ind = [0,1,2,3,4,5]
name_ind[a], name_ind[5] = 5, a
 
df.index = name_ind
df.sort_index(ascending=True)
Пока не получается преобразовать значение индекса в число int

Добавлено через 17 минут
Вот так вроде бы получается. Но мне кажется должен быть способ получше.
Python
1
2
3
4
5
6
a = int(df[df.Name == 'AC'].index.values) # индекс искомой строки в формате int
name_ind = [0,1,2,3,4,5]
name_ind[a], name_ind[5] = 5, a # новый список индексов
 
df.index = name_ind
df1 = df.sort_index(ascending=True)
0
Лучшие ответы (1)
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
27.02.2021, 16:37
Ответы с готовыми решениями:

Поменять местами строки
В задании матрицы записываются в файл (файлы), считываются из файла (-ов) и результат выводится в файл. В матрице А(8,7) поменять 2-ю и 4-ю...

Поменять местами строки матрицы
Объявить функцию change(A,i,j), которая в матрице A меняет местами строки i и j. (python)

Поменять местами строки матрицы
написать программу которая изменит местами последний ряд с рядом который имеет минимальный положительный элемент

2
Эксперт Python
8837 / 4489 / 1864
Регистрация: 27.03.2020
Сообщений: 7,311
27.02.2021, 19:50
Лучший ответ Сообщение было отмечено VistaSV30 как решение

Решение

VistaSV30,
Python
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
import numpy as np
import pandas as pd
import itertools as it # функции комбинаторики
 
# создание массива
np.random.seed(1000)
df = pd.DataFrame(np.random.randint(10, 99, (6, 8))) # создание фрейма
df[0] = [i[0]+i[1] for i in it.permutations('ABC', 2)] # строковые значения для первой колонки
df.columns = ['Name', 'c1', 'c2', 'c3', 'c4', 'c5', 'c6', 'c7'] # назначить имена колонок
print(df)
 
# Закоментированно ниже - алгоритм. Можно вместо
# длинного оператора их использовать для
# лучшего "чтения" кода
#f = df.ix[df['Name'] == 'AB', 1:].values[0]
#g = df.ix[df['Name'] == 'BA', 1:].values[0]
#df.ix[df['Name'] == 'BA', 1:] = f
#df.ix[df['Name'] == 'AB', 1:] = g
 
df.ix[df['Name'] == 'AB', 1:], df.ix[df['Name'] == 'BA', 1:] =\
df.ix[df['Name'] == 'BA', 1:].values[0], df.ix[df['Name'] == 'AB', 1:].values[0]
print(df)
1
 Аватар для VistaSV30
986 / 330 / 79
Регистрация: 10.04.2012
Сообщений: 1,239
Записей в блоге: 4
01.03.2021, 17:08  [ТС]
Еще вариант - переместить искомую строку в конец фрейма и обновить индексы
Python
1
2
3
4
5
6
# переместить 'AB' в конец фрейма
a = int(df[df[0] == 'AB'].index.values)
b = df[df[0] == 'AB']
df = df.drop([a]) # удалить строку
df = df.append(b) # присоединить сткроку в конец фрейма
df = df.reset_index(drop=True) # обновить нумерацию индексов
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
01.03.2021, 17:08
Помогаю со студенческими работами здесь

Поменять местами строки матрицы
Ребята, нужна помощь. Потому что я не знаю как решить эту задачу Задано список (в). Написать программу, которая изменит местами первую...

Поменять местами строки в файле
Доброго времени суток. начала работать с файлами, не могу разобраться как менять строки местами, в самом файле? из учётной системы я...

Поменять местами строки матрицы
Описать процедуру SwapRow(A, M, N, K1, K2), осуществляющую перемену местами строк вещественной матрицы A размера M×N с номерами K1 и...

Поменять местами строки и столбцы в матрице
Как в Python поменять строки и столбцы местами в матрице

В матрице поменять местами строки и столбцы
В данной действительной матрице размера n⨯m ( n≥3 , m≥3 ) поменять местами: а)строки с номерами 2 и n-1; б)столбцы с номерами 3 и n-2.


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему
Новые блоги и статьи
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Access
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
Мысли в слух
kumehtar 18.11.2025
Кстати, совсем недавно имел разговор на тему медитаций с людьми. И обнаружил, что они вообще не понимают что такое медитация и зачем она нужна. Самые базовые вещи. Для них это - когда просто люди. . .
Создание Single Page Application на фреймах
krapotkin 16.11.2025
Статья исключительно для начинающих. Подходы оригинальностью не блещут. В век Веб все очень привыкли к дизайну Single-Page-Application . Быстренько разберем подход "на фреймах". Мы делаем одну. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru