-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathexample.datalogger.py
executable file
·99 lines (77 loc) · 3.02 KB
/
example.datalogger.py
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
#!/usr/bin/env python
# -*- encoding: UTF8 -*-
# Author: Philipp Klaus, philipp.l.klaus AT web.de
# This file is part of avrnetio.
#
# avrnetio is free software: you can redistribute it and/or modify
# it under the terms of the GNU General Public License as published by
# the Free Software Foundation, either version 3 of the License, or
# (at your option) any later version.
#
# avrnetio is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU General Public License for more details.
#
# You should have received a copy of the GNU General Public License
# along with avrnetio. If not, see <http://www.gnu.org/licenses/>.
# example how to use the avrnetio class
## import the avrnetio class:
import avrnetio
## for debugging (set debug mark with pdb.set_trace() )
import pdb
## for sys.exit(1)
import sys
##for OptionParser() (see <http://optik.sourceforge.net/>)
from optparse import OptionParser
## for time.sleep()
import time
host = "192.168.102.3"
defaultFilename = "./logged_data.txt"
refVoltage = 4.36
def main():
parser = OptionParser()
parser.add_option("-f", "--file",
action="store", type="string", dest="filename",
help="write data to FILE", metavar="FILE")
parser.add_option("-q", "--quiet",
action="store_false", dest="verbose", default=1,
help="don't print status messages to stdout")
(options, args) = parser.parse_args()
if options.filename == None:
options.filename = defaultFilename
print "Logging to " + defaultFilename + " as no filenmame was supplied on the command line."
print "Writing to file: %s" % options.filename
logfile = open(options.filename, 'w')
logfile.write("Starting new logfile"+"\n")
try:
try:
netio = avrnetio.Avrnetio(host)
netio.set_ref_ep(refVoltage)
except StandardError as e:
print("could not connect" + e.value)
raise KeyboardInterrupt()
while 1:
try:
ADCs = netio.get_adcs()
ADCsInVolts = netio.get_adcs_as_volts()
except NameError, message:
print(message)
raise KeyboardInterrupt()
except StandardError, message:
print(message)
#print("AVR-NET-IO not available anymore. EXITING.")
raise KeyboardInterrupt()
for ADC in ADCs :
logfile.write("%s " % (ADC))
logfile.write("\n")
for ADCInVolts in ADCsInVolts :
logfile.write("%.2fV " % (ADCInVolts))
logfile.write("\n")
time.sleep(1)
except KeyboardInterrupt:
print "[Ctrl]-[C] pressed: closing logfile."
netio = None
logfile.close()
if __name__ == '__main__':
main()