尝试将y变量读入pyplot.s时出现索引器错误

2024-09-28 05:22:05 发布

您现在位置:Python中文网/ 问答频道 /正文

我试图创建的最终产品是一个程序,它从csv(附加的,称为输出UTC.csv)并允许用户根据所选列绘制散点图。我决定先创建预选列的图形,然后再使用rawinput和变量。所以,我遇到的问题是python将数据读入pyplot的方式。数据取自输入csv并写入它自己的文件(Qout14.csv),我试图从中绘图。不幸的是,我得到一个索引器,即使x和y变量列表是相同的长度。在进行一些读取时,我想知道问题是否是y数据没有逗号分隔实例中的数据,因此它可能只是将所有y作为字符串读取,因此列表中没有任何其他内容。令人困惑的是,同一行代码适用于变量的另一端,即x。有人能指出我的错误在哪里吗?你知道吗

Example of Inputs(Columns 1 and 7 of OutputC.csv):
pcp Qout14
2.3 7.20E-03
3   1.34E-02
3.3 1.50E-02
2.3 8.25E-03
3   1.32E-02
2.5 9.47E-03
3   1.28E-02
3.6 1.81E-02
2.5 1.02E-02
2.5 9.44E-03
2   6.00E-03
2.8 1.17E-02
2.8 1.12E-02
2.8 1.16E-02

Traceback (most recent call last): File "C:\Users\jmiyama\Desktop\Python Files\OutputCtoScatterplot.py", line 48, in main() File "C:\Users\jmiyama\Desktop\Python Files\OutputCtoScatterplot.py", line 35, in main y = [row.split(',')[1] for row in data[1:]] IndexError: list index out of range

import csv
import numpy as np
import matplotlib.pyplot as plt
import pandas
import collections

def getColumn(filename, column):
    results = csv.reader(open(filename), dialect='excel')   
    return [result[column] for result in results]

def dictcolumn():
    pcp = getColumn("C:\\Users\\jmiyama\\Desktop\\Python Files\\OutputC.csv",1)
    Qout14 = getColumn("C:\\Users\\jmiyama\\Desktop\\Python Files\\OutputC.csv",7)
    scatter={}
    scatter["pcp"]= pcp
    scatter["Qout14"]= Qout14
    return scatter

def main():
    scatter = dictcolumn()
    file = 'Qout14.csv'
    with open(file, 'w+') as csv_file:
        writer = csv.writer(csv_file, lineterminator='\n')
        writer.writerows(zip(*scatter.values()))

    with open("Qout14.csv") as f:
        data = f.read()
    data = data.split('\n')
    # trying to split the zipped values into columns
    x = [row.split(',')[0] for row in data[1:]]
    #THE CODE WORKS UP TO HERE
    y = [row.split(',')[1] for row in data[1:]]
    fig = plt.figure()
    ax = fig.add_subplot(111)
    ax.grid()

    plt.scatter(x,y)
    plt.xlabel('pcp')
    plt.ylabel('Qout14')
    plt.title('Qout14 vs pcp')
    plt.show()

if __name__ == '__main__':
   main()

Tags: csv数据inimportdatamainpltusers
1条回答
网友
1楼 · 发布于 2024-09-28 05:22:05

data = data.split('\n')似乎要在末尾添加额外的“空白”行,所以下面的方法可以。你知道吗

x = [row.split(',')[0] for row in data[1:-1]]
y = [row.split(',')[1] for row in data[1:-1]]

相关问题 更多 >

    热门问题