如果我在CMD上运行python文件,则不会创建csv文件

时间:2019-06-28 15:09:25

标签: python pandas csv cmd

我有一个python文件,可将数据写入csv文件。 我还有另一个python文件,可从csv文件读取数据并将其显示在绘图上。

当我尝试在CMD上运行第一个文件时,在打印本应写入csv文件的值时未创建csv文件。

当我使用IDLE运行第一个文件时,我可以看到正在创建csv文件并将数据写入其中。另外,我可以使用第二个文件查看csv文件中的更改,因为它每秒检查一次更新。

有人知道为什么它不适用于CMD吗?

使用python工作了4个月

第一个文件:

https://www.codepile.net/pile/eZ68EbXd

import csv
import random
import time

x_value = 0
total_1 = 1000
total_2 = 1000

fieldnames = ["x_value", "total_1", "total_2"]


with open('data.csv', 'w') as csv_file:
    csv_writer = csv.DictWriter(csv_file, fieldnames=fieldnames)
    csv_writer.writeheader()

while True:

    with open('data.csv', 'a') as csv_file:
        csv_writer = csv.DictWriter(csv_file, fieldnames=fieldnames)

        info = {
            "x_value": x_value,
            "total_1": total_1,
            "total_2": total_2
        }

        csv_writer.writerow(info)
        print(x_value, total_1, total_2)

        x_value += 1
        total_1 = total_1 + random.randint(-6, 8)
        total_2 = total_2 + random.randint(-5, 6)

    time.sleep(1)

第二个文件:https://www.codepile.net/pile/GndPGGn1

import random
from itertools import count
import pandas as pd 
import matplotlib.pyplot as plt 
from matplotlib.animation import FuncAnimation

plt.style.use('fivethirtyeight')

x_vals = []
y_vals = []

index = count()

def animate(i):
    data = pd.read_csv('data.csv')
    x = data['x_value']
    y1 = data['total_1']
    y2 = data['total_2']

    plt.cla()
    plt.plot(x,y1,label = 'Channel 1')
    plt.plot(x,y2,label = 'Channel 2')

    plt.legend(loc= 'upper left')
    plt.tight_layout()

ani = FuncAnimation(plt.gcf(),animate,interval= 1000)    

plt.tight_layout()
plt.show()

谢谢

btw我正在运行python 3.7.2

0 个答案:

没有答案