将数据从python脚本传输到.csv或.txt文件

时间:2020-04-16 17:21:07

标签: python shell csv pipe raspberry-pi3

我想监视我公寓内的空气质量(楼下的邻居是个狂热的吸烟者)。为此,我将Raspberry Pie 3 Model B +与Enviro +连接。

在终端中,我可以运行用于测量小颗粒的脚本。 python particulates.py参见。 https://github.com/pimoroni/enviroplus-python/blob/master/examples/particulates.py

然后它运行并在终端中显示数据,如下图所示:(是的,我乐于学习,比编码更好)。 Text

我有兴趣在文本文件或csv中记录数据,因此我在考虑是否有一种方法可以将屏幕上显示的数据直接传输到csv或txt文件中。我知道,我可能可以编写一个简单且精巧的Python脚本,但是我听到了Linux的许多赞誉,我想尝试一下。此外,我在一个论坛上看到:

Awk Sed 是您的Shell脚本朋友。 在Linux中,一切都是文件,Awk和Sed可以写入/编辑文件。 每个Linux操作系统附带的可怕的旧东西都可以正常工作。

如果您使用Web服务器,则不需要所有x11桌面膨胀功能,只需一个无头的Linux操作系统即可。 轻松将所有这些安装在128MB卡上。 Busybox有一个Web服务器,或者您可以从许多选项中进行选择。 我使用Shell脚本和Awk / Sed即时重写CGI / HTML文件。

来源:https://www.raspberrypi.org/forums/viewtopic.php?t=248733

我在终端中输入了以下内容:

python Particulates.py > data.csv

我也尝试过:

python Particulates.py | data.csv

数据显示在屏幕上,创建了一个csv文件,但是两个选项的data.csv为空。如果我的理解是正确的,则需要将particles.py的标准输出放入data.csv。那里应该缺少一些东西,因为,我所得到的与这位awk / sed倡导者在论坛上做的广告相去甚远。

有什么线索可以做到吗?如果我要绘制结果,我应该使用gnuplot吗?我可以在同一条线中使用它吗,例如在一条管道中使用?

谢谢您的帮助。

1 个答案:

答案 0 :(得分:1)

检查库代码https://github.com/pimoroni/pms5003-python/blob/master/library/pms5003/init.py#L66,以了解每一列中包含哪些值:

    def __repr__(self):
        return """
PM1.0 ug/m3 (ultrafine particles):                             {}
PM2.5 ug/m3 (combustion particles, organic compounds, metals): {}
PM10 ug/m3  (dust, pollen, mould spores):                      {}
PM1.0 ug/m3 (atmos env):                                       {}
PM2.5 ug/m3 (atmos env):                                       {}
PM10 ug/m3 (atmos env):                                        {}
>0.3um in 0.1L air:                                            {}
>0.5um in 0.1L air:                                            {}
>1.0um in 0.1L air:                                            {}
>2.5um in 0.1L air:                                            {}
>5.0um in 0.1L air:                                            {}
>10um in 0.1L air:                                             {}
""".format(*self.data[:-2], checksum=self.checksum)

并使用此数据写入CSV:

import csv
from datetime import datetime


pms5003 = PMS5003()
time.sleep(1.0)

try:
    while True:
        try:
            with open('pms5003.csv', 'a', newline='') as csvfile:
                writer = csv.writer(csvfile, delimiter=' ', quotechar='|', quoting=csv.QUOTE_MINIMAL)
                data = pms5003.read()  # PMS5003Data instance
                dt = datetime.now()
                writer.writerow([dt.isoformat()] + list(data.data[:-2]))
        except ReadTimeoutError:
            pms5003 = PMS5003()
except KeyboardInterrupt:
    pass