SLAVA / metrics.py
Y1OV's picture
Upload 2 files
1d8afef verified
raw
history blame
2.13 kB
import pandas as pd
import streamlit as st
# Загрузка данных
file_path = 'metrics.xlsx'
sheet_name = 'ИТОГ'
df = pd.read_excel(file_path, sheet_name=sheet_name)
# Обработка данных
df.set_index('Модель', inplace=True)
df.rename(columns={
'Unnamed: 2': 'Выбор ответа (мультивыбор)',
'Unnamed: 3': 'Выбор ответа (мультивыбор)',
'Unnamed: 6': 'Указание последовательности',
'Unnamed: 7': 'Указание последовательности',
'Unnamed: 9': 'Установление соответствия',
'Unnamed: 10': 'Установление соответствия',
'Unnamed: 12': 'Открытый ответ',
'Unnamed: 13': 'Открытый ответ'
}, inplace=True)
df.drop(columns=['Unnamed: 15', 'EM'], inplace=True)
new_columns_reversed = df.columns + ' ' + df.iloc[0]
df.columns = new_columns_reversed
df = df.drop(df.index[0])
df.rename(columns={df.columns[-1]: 'ИТОГОВЫЙ рейтинг'}, inplace=True)
# Название приложения
st.title("Просмотр таблицы с выбором колонок")
# Получаем список колонок
columns = df.columns.tolist()
# Указываем начальное значение по умолчанию — 'ИТОГОВЫЙ рейтинг'
default_column = ['ИТОГОВЫЙ рейтинг']
# Мультивыбор для выбора колонок с начальным значением
selected_columns = st.multiselect("Выберите колонки для отображения", columns, default=default_column)
# Используем стили для отображения полного текста в ячейках
st.write(
"""
<style>
.dataframe td {
white-space: nowrap;
text-overflow: clip;
overflow: visible;
max-width: 400px;
}
</style>
""",
unsafe_allow_html=True
)
# Отображение выбранных колонок
st.dataframe(df[selected_columns], height=800)