首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >python分析数据csv文件

python分析数据csv文件
EN

Stack Overflow用户
提问于 2019-02-17 02:59:10
回答 1查看 70关注 0票数 0

我一直在尝试简化我分析响应时间的数据的方式,因为不可能为每个参与者手动进行分析。但是,由于某些原因,我的代码似乎无法工作。所以基本上我想查看块1到4的响应时间,精度为1,prob_trial为1,但是我的代码显然不允许我这样做。你有什么意见建议?

我的csv文件内容如下所示:

代码语言:javascript
复制
Block,Trial_number,Position,Probability Position,Probability State,Probability trial,Response,Accuracy,RT (ms)
1,1,N,None,None,1,N,1,976.451326394
1,2,X,None,None,1,X,1,935.360659205
1,3,M,0.9,0.81,2,M,1,936.700751889
1,4,Z,0.81,None,2,Z,1,904.942057532
1,5,X,0.9,0.81,2,X,1,952.641545009
1,6,Z,0.81,None,2,Z,1,553.098919248

我的代码是:

代码语言:javascript
复制
for fnam in d_list:
    if fnam[-4:] == '.csv':

        f_in = path1 + '/' + fnam



        with open(f_in) as csvfile:
            reader = csv.DictReader(csvfile)

            for row in reader:


                block_no.append(int(row['Block']))
                trial_no.append(int(row['Trial_number']))
                prob_trial.append(int(row['Probability trial']))
                accuracy.append(int(row['Accuracy']))
                rt.append(float(row['RT (ms)']))

           for x in block_no:
                if x < 5:f
                    for y in accuracy:
                        if y == 1:
                            for z in prob_trial:
                                if z == 1:
                                    epoch1_improbable.append(rt)

           epoch1_improbable_rt = mean(epoch1_improbable)
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2019-02-17 03:08:48

这是pandas的完美用例,您可以通过以下方式获得所需的结果

代码语言:javascript
复制
import pandas as pd
df = pd.read_csv('data.csv')
mask = (df['Block'] < 5) & (df['Accuracy'] == 1) & (df['Probability trial'] == 1)
print(df[mask]['RT (ms)'].mean())  # 955.9059927994999
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/54726572

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档