С Новым годом! Форум программистов, компьютерный форум, киберфорум
Python
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 5.00/8: Рейтинг темы: голосов - 8, средняя оценка - 5.00
0 / 0 / 0
Регистрация: 13.09.2015
Сообщений: 42

Перевернуть или транспонировать DataFrame

05.01.2023, 16:30. Показов 1897. Ответов 2

Студворк — интернет-сервис помощи студентам
Приветствую Граждане.
Имеется в наличии DataFrame вот такого вида EURUSD1_1.csv (увы такого формата нет пришлось заархивировать EURUSD1_1.zip)файл во вложении. Произведя не хитрые манипуляции получаем файл ЕСКСЕЛЬ вот такого вида output.xlsx тоже приложил.
Подскажите как данный


Python
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
from tkinter import Tk
from tkinter.filedialog import askopenfilename
import pandas as pd
import xlwt as xlwt
 
def filename():
    Tk().withdraw()  # we don't want a full GUI, so keep the root window from appearing
    strn = askopenfilename(filetypes=(("CSV files", "*.csv"),))  # show an "Open" dialog box and return the path to the selected file
    return (strn)
 
val = filename()
x = val.replace('/', '\\')
df = pd.read_csv(x, delimiter=',', names=['data', 'time', 'Open', 'Max', 'Min', 'Close', 'Volume'])
 
df = df.drop(['Max','Min', 'Volume'], axis=1)
df['O-C'] = df.Open - df.Close
df = df.drop(['Open','Close'], axis=1)
# create excel writer object
writer =d.ExcelWriter('C:/Users/Admin/Documents/PLoad/data/output.xlsx')
# write dataframe to excel
df.to_excel(writer)
# save the excel
writer.save()
Вложения
Тип файла: xlsx output.xlsx (54.6 Кб, 5 просмотров)
Тип файла: zip EURUSD1_1.zip (21.0 Кб, 2 просмотров)
0
Лучшие ответы (1)
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
05.01.2023, 16:30
Ответы с готовыми решениями:

Новый Dataframe с информацией из старого Dataframe
У меня есть такой Dataframe. Мне нужно посчитать количество каждого значения из столбца Message для каждого номера из...

Перевернуть экран (изменить ориентацию desktop) на 180? Или саму форму приложения перевернуть
Delphi XE3. Как?

Pandas. Изменение значений Dataframe исходя из другого Dataframe
Добрый день. Прошу подсказать с реализаций следующего алгоритма: я загружаю из файла примерно следующий Dataframe(db): ...

2
0 / 0 / 0
Регистрация: 13.09.2015
Сообщений: 42
05.01.2023, 16:47  [ТС]
перевернуть чтобы в ексель выходила таблица с первой строкой время, вторая строка данные из колонки O-C
и данные колонки чередовались каждый час.
То есть первый час 60 минут 60 колонок в строку
следующая строка опять время от 00 до 59
следующая строка данные из колонки O-C
0
Эксперт Python
8848 / 4500 / 1864
Регистрация: 27.03.2020
Сообщений: 7,316
05.01.2023, 21:37
Лучший ответ Сообщение было отмечено AlexsSStep как решение

Решение

AlexsSStep, Так?
Python
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
 # -*- coding: utf-8 -*-
"""Untitled2.ipynb
 
Automatically generated by Colaboratory.
 
Original file is located at
    https://colab.research.google.com/drive/1uns-JooDaT0Ng83GXRE1aTSkBrrhiVrU
"""
 
import pandas as pd
 
df = pd.read_csv('/content/drive/MyDrive/EURUSD1_1.csv', header=None)
df.columns = ['date', 'time', 'open', 'max', 'min', 'close', 'val']
df['diff'] = df['open'] - df['close']
df['date_hour'] = df['date'] + ' ' + df['time'].map(lambda x: x[:2]) #pd.to_timedelta(df['time'].dt.time.astype(str))
df['minutes'] = df['time'].map(lambda x: x[-2:])
 
df1 = df[['date_hour', 'minutes', 'diff']]
df1 = df1.set_index(['date_hour', 'minutes'], drop=True)
df1 = df1.unstack(level=-1)
print(df1)
Добавлено через 43 минуты
Если нужно именно
То есть первый час 60 минут 60 колонок в строку
следующая строка опять время от 00 до 59
следующая строка данные из колонки O-C
, то:
Python
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
 import pandas as pd
from datetime import datetime
 
cd = lambda x: datetime.strptime(str(x), '%H:%M')
df = pd.read_csv('/content/drive/MyDrive/EURUSD1_1.csv', header=None)#, parse_dates=[0, 1])
df.columns = ['date', 'time', 'open', 'max', 'min', 'close', 'val']
df['diff'] = df['open'] - df['close']
df['date_hour'] = df['date'] + ' ' + df['time'].map(lambda x: x[:2]) #pd.to_timedelta(df['time'].dt.time.astype(str))
df['minutes'] = df['time'].map(lambda x: x[-2:])
 
df1 = df[['date_hour', 'minutes', 'diff']]
df1 = df1.set_index(['date_hour', 'minutes'], drop=True)
df1 = df1.unstack(level=-1)
 
#######################################
n = len(df1)
df1.index = range(1, 2*n, 2)
df1 = df1.droplevel(0, axis=1)
df2 = pd.DataFrame([df1.columns.tolist() for _ in range(n)],
                   index = range(0, 2*n, 2),
                   columns = df1.columns)
df_res = pd.concat([df1, df2]).sort_index()
df_res
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
05.01.2023, 21:37
Помогаю со студенческими работами здесь

Транспонировать матрицу или упорядочить строки по неубыванию
дана квадратная матрица порядка n(n=10). Если сумма всех положительных элемент во строк больше суммы всех отрицательных элементов то...

Транспонировать матрицу и найти невозрастающие или неубывающие строки
Задана матрица A(n,n). Зеркально отразить ее относительно главной диагонали. В преобразованной матрице найти строки, элементы которой ...

Перевернуть текст или страницу в Word 2007
отдельную страницу перевернуть хочу на 90*. или пусть текст идет соответствукющим образом. гуглил ничёго не нагуглил или не...

Как перевернуть массив или данные в ListBox
В ListBox отображает вначале более старые данные, а нужно новые. var obj = (from o in dj.job_info_dbs ...

Найти количество простых чисел в массиве. Перевернуть все нечетные строки матрицы. Перевернуть каждое четное слово в строке
Ребята помогите разобраться в коде программы, написав подробные комменты к данной проге. Спасибо! Постановка задачи 1. Используя...


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

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему
Новые блоги и статьи
Расчёт переходных процессов в цепи постоянного тока
igorrr37 16.01.2026
/ * Дана цепь постоянного тока с R, L, C, k(ключ), U, E, J. Программа составляет систему уравнений по 1 и 2 законам Кирхгофа, решает её и находит токи на L и напряжения на C в установ. режимах до и. . .
Восстановить юзерскрипты Greasemonkey из бэкапа браузера
damix 15.01.2026
Если восстановить из бэкапа профиль Firefox после переустановки винды, то список юзерскриптов в Greasemonkey будет пустым. Но восстановить их можно так. Для этого понадобится консольная утилита. . .
Изучаю kubernetes
lagorue 13.01.2026
А пригодятся-ли мне знания kubernetes в России?
Сукцессия микоризы: основная теория в виде двух уравнений.
anaschu 11.01.2026
https:/ / rutube. ru/ video/ 7a537f578d808e67a3c6fd818a44a5c4/
WordPad для Windows 11
Jel 10.01.2026
WordPad для Windows 11 — это приложение, которое восстанавливает классический текстовый редактор WordPad в операционной системе Windows 11. После того как Microsoft исключила WordPad из. . .
Classic Notepad for Windows 11
Jel 10.01.2026
Old Classic Notepad for Windows 11 Приложение для Windows 11, позволяющее пользователям вернуть классическую версию текстового редактора «Блокнот» из Windows 10. Программа предоставляет более. . .
Почему дизайн решает?
Neotwalker 09.01.2026
В современном мире, где конкуренция за внимание потребителя достигла пика, дизайн становится мощным инструментом для успеха бренда. Это не просто красивый внешний вид продукта или сайта — это. . .
Модель микоризы: классовый агентный подход 3
anaschu 06.01.2026
aa0a7f55b50dd51c5ec569d2d10c54f6/ O1rJuneU_ls https:/ / vkvideo. ru/ video-115721503_456239114
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru