Spaces:
Runtime error
Runtime error
File size: 5,757 Bytes
3381bb7 e926da5 3381bb7 2a2ab7a e926da5 3381bb7 66bda0b 3381bb7 52abfc6 3381bb7 52abfc6 66bda0b 3381bb7 52abfc6 3381bb7 52abfc6 3381bb7 c04ea23 3381bb7 c04ea23 3381bb7 |
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 |
# import datetime
import os
import gradio as gr
import numpy as np
import pandas as pd
os.environ["no_proxy"] = "localhost,127.0.0.1,::1"
#######################################################################################
def read_ui(username,password):
if (username=='' or password==''):
return '请填写完整信息'
user_login_df=pd.read_csv('./user_login/login.csv',encoding='gbk',converters = {'password':str})
user_login=user_login_df.set_index('username')['password'].T.to_dict()
user_data1_df=pd.read_csv('./user_data/data_1.csv',encoding='gbk')
user_data2_df=pd.read_csv('./user_data/data_2.csv',encoding='gbk',converters ={'senti_flt':float,'hobby_flt':float,'all_flt':float})
results=''
is_usn=(username in user_login)
if(is_usn):
pswd_crct=(password==user_login[username])
if(is_usn and pswd_crct):
report1=user_data1_df[user_data1_df['username'] == username]
report1=np.array(report1).tolist()
report2=user_data2_df[user_data2_df['username'] == username]
report2=np.array(report2).tolist()
results='用户名:'+username+'\n'
for i in range(len(report1)):
line1=report1[i]
results=results+'第'+str(i+1)+'次量表测试 '+'日期:'+str(line1[1])+' 时间:'+str(line1[2])+'\n'
results=results+'量表分数:'+str(line1[3])+'\n结果解释:'+str(line1[4])+'\n建议:'+str(line1[5])+'\n'
results+='\n'
for i in range (len(report2)):
line2=report2[i]
results=results+'第'+str(i+1)+'次咨询 '+'日期:'+str(line2[1])+' 时间:'+str(line2[2])+'\n'
results=results+'睡眠情况:'+str(line2[3])+'\n食欲情况:'+str(line2[4])+'\n情绪情况:'+str(line2[5])+'\n情绪分数:'+str(line2[6])+'\n情绪回答:'+str(line2[7])+'\n轻生倾向:'+str(line2[8])+'\n'
results=results+'兴趣爱好分数:'+str(line2[9])+'\n兴趣爱好回答:'+str(line2[10])+'\n近期总体分数:'+str(line2[11])+'\n近期总体回答:'+str(line2[12])+'\n'+'最终建议:'+line2[13]+'\n\n'
elif(is_usn):
results='密码错误,无法读取报告数据。'
else:
results='账户不存在,无法读取报告数据。'
return results
def delete_ui(username,password):
if (username=='' or password==''):
return '请填写完整信息'
user_login_df=pd.read_csv('./user_login/login.csv',encoding='gbk',converters = {'password':str})
user_login=user_login_df.set_index('username')['password'].T.to_dict()
user_data1_df=pd.read_csv('./user_data/data_1.csv',encoding='gbk')
user_data2_df=pd.read_csv('./user_data/data_2.csv',encoding='gbk',converters ={'senti_flt':float,'hobby_flt':float,'all_flt':float})
results=''
is_usn=(username in user_login)
if(is_usn):
pswd_crct=(password==user_login[username])
if(is_usn and pswd_crct):
user_data1_df.drop(user_data1_df[user_data1_df['username'] == username].index,inplace=True)
user_data2_df.drop(user_data2_df[user_data2_df['username'] == username].index,inplace=True)
user_login_df.drop(user_login_df[user_login_df['username'] == username].index,inplace=True)
user_login_df.to_csv('./user_login/login.csv',encoding='gbk',index=False)
user_data1_df.to_csv('./user_data/data_1.csv',encoding='gbk',index=False)
user_data2_df.to_csv('./user_data/data_2.csv',encoding='gbk',index=False)
results='已删除对应账户所有数据'
elif(is_usn):
results='密码错误,无法删除报告数据。'
else:
results='账户不存在,无法删除报告数据。'
return results
###########################################################################################
def clear_info():
return (
gr.Textbox(""),
gr.Textbox(""),
gr.Textbox(""),
)
with gr.Blocks() as user_center:
with gr.Tab("查询历史"):
with gr.Row():
gr.HTML("<h3 style='text-align:center;'>输入账号密码查看个人历史记录</h3>")
with gr.Row():
with gr.Column(scale=1):
input_name1 = gr.Textbox(label="用户名",interactive=True)
input_pwd1 = gr.Textbox(label="密码",interactive=True)
with gr.Row():
clear_button1 = gr.Button("清除")
login_button1 = gr.Button("登录")
with gr.Column(scale=1):
output_info1 = gr.Textbox(label="输出", lines=5,interactive=False)
with gr.Tab("清空数据"):
with gr.Row():
gr.HTML("<h3 style='text-align:center;'>输入账号密码清空个人历史记录与账号</h3>")
with gr.Row():
with gr.Column(scale=1):
input_name2 = gr.Textbox(label="用户名",interactive=True)
input_pwd2 = gr.Textbox(label="密码",interactive=True)
with gr.Row():
clear_button2 = gr.Button("清除")
delete_button2 = gr.Button("登录")
with gr.Column(scale=1):
output_info2 = gr.Textbox(label="输出", lines=5,interactive=False)
clear_button1.click(
fn=clear_info,
inputs=[],
outputs=[input_name1, input_pwd1, output_info1],
)
login_button1.click(
fn=read_ui,
inputs=[input_name1, input_pwd1],
outputs=output_info1,
)
clear_button2.click(
fn=clear_info,
inputs=[],
outputs=[input_name2, input_pwd2, output_info2],
)
delete_button2.click(
fn=delete_ui,
inputs=[],
outputs=[output_info2],
) |