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

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

05.01.2023, 16:30. Показов 1967. Ответов 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
8851 / 4502 / 1864
Регистрация: 27.03.2020
Сообщений: 7,317
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
Ответ Создать тему
Новые блоги и статьи
Знаешь почему 90% людей редко бывают счастливыми?
kumehtar 14.04.2026
Потому что они ждут. Ждут выходных, ждут отпуска, ждут удачного момента. . . а удачный момент так и не приходит.
Фиксация колонок в отчете СКД
Maks 14.04.2026
Фиксация колонок в СКД отчета типа Таблица. Задача: зафиксировать три левых колонки в отчете. Процедура ПриКомпоновкеРезультата(ДокументРезультат, ДанныеРасшифровки, СтандартнаяОбработка) / / . . .
Настройки VS Code
Loafer 13.04.2026
{ "cmake. configureOnOpen": false, "diffEditor. ignoreTrimWhitespace": true, "editor. guides. bracketPairs": "active", "extensions. ignoreRecommendations": true, . . .
Оптимизация кода на разграничение прав доступа к элементам формы
Maks 13.04.2026
Алгоритм из решения ниже реализован на нетиповом документе, разработанного в конфигурации КА2. Задачи, как таковой, поставлено не было, проделанное ниже исключительно моя инициатива. Было так:. . .
Контроль заполнения и очистка дат в зависимости от значения перечислений
Maks 12.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеПерсонала", разработанного в конфигурации КА2. Задача: реализовать контроль корректности заполнения дат назначения. . .
Архитектура слоя интернета для сервера-слоя.
Hrethgir 11.04.2026
В продолжение https:/ / www. cyberforum. ru/ blogs/ 223907/ 10860. html Знаешь что я подумал? Раз мы все источники пишем в голове ветки, то ничего не мешает добавить в голову такой источник, который сам. . .
Подстановка значения реквизита справочника в табличную часть документа
Maks 10.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеПерсонала", разработанного в конфигурации КА2. Задача: при выборе сотрудника (справочник Сотрудники) в ТЧ документа. . .
Очистка реквизитов документа при копировании
Maks 09.04.2026
Алгоритм из решения ниже применим как для типовых, так и для нетиповых документов на самых различных конфигурациях. Задача: при копировании документа очищать определенные реквизиты и табличную. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru