pythonmodulexively

What Does This Output Represent?


I'm trying to get my RPi to send temp data to Xively and I'm having a horrible time getting my code to work. This is the latest reponse I get when I run the python script...

Traceback (most recent call last):
File "xively1.py", line 11, in <module>
import xively               # for Xively 
File "/home/pi/xively/xively.py", line 11, in <module>
FEED_ID = os.environ["736915202"]
File "/usr/lib/python2.7/UserDict.py", line 23, in __getitem__
raise KeyError(key)
KeyError: '736915202'

Can someone explain to me what this means and what I need to do to correct? Thanks.

#!/usr/bin/env python

# This program reads two DS18B20 1-wire temperature sensors and sends the values to
# Xively  https://xively.com/feeds/360495937

# tempF[0] is the reading from the outdoor tempersture sensor '28-0000059f6ece'
# tempF[1] is the reading from the indoor temperature sensor '28-0000059fa9ce'
outdoor = 0
indoor = 1

import xively               # for Xively
import time
import datetime
import os                   # for 1-wire
import glob                 # for 1-wire

def read_temp_raw(): #a function that grabs the raw temperatures data from the sensors
    f_1 = open(device_file[0], 'r') # first DS18B20
    lines_1 = f_1.readlines()
    f_1.close()
    f_2 = open(device_file[1], 'r') # second DS18B20
    lines_2 = f_2.readlines()
    f_2.close()
    return lines_1 + lines_2

def read_temp(): #a function that checks that the connections were good
    lines = read_temp_raw()
    while lines[0].strip()[-3:] != 'YES' or lines[2].strip()[-3:] != 'YES':
        time.sleep(0.2)
        lines = read_temp_raw()
    equals_pos = lines[1].find('t='), lines[3].find('t=')
    tempC = float(lines[1][equals_pos[0]+2:])/1000, float(lines[3]    [equals_pos[1]+2:])/1000
    tempF =  round(tempC[0] * 9.0 / 5.0 + 32.0,1), round(tempC[1] * 9.0 / 5.0 + 32.0,1)
    return  tempF
def send_to_Xively(TempF):
    XIVELY_FEED_ID = "736915202"
    XIVELY_API_KEY = "QA6mqStQIqCFLOXtA4tzxiFpv8cqHNaYr1MFjRZdrphGwxYN"
#def send_to_Xively(TempF):
    now = datetime.datetime.utcnow()
    try:
        print "Sending to Xively...",
        xivelyapi = xively.XivelyAPIClient(XIVELY_API_KEY)
        xivelyfeed = xivelyapi.feeds.get(XIVELY_FEED_ID)
        xivelyfeed.datastreams = [
          xively.Datastream(id='temp0', current_value=round(TempF[outdoor],1), at=now),
          xively.Datastream(id='temp1', current_value=round(TempF[indoor],1), at=now)
        ]
        xivelyfeed.update()
        print "OK"
    except requests.HTTPError as e:
        print "HTTPError({0}): {1}".format(e.errno, e.strerror)

# this part for the 1-wire DS18S20
os.system('modprobe w1-gpio')
os.system('modprobe w1-therm')

#set up the locations of the sensors in the system
device_folder = glob.glob('/sys/bus/w1/devices/28*')
device_file = [device_folder[0] + '/w1_slave', device_folder[1] + '/w1_slave']

# main program
TempF = read_temp()
send_to_Xively(TempF)

Solution

  • The xively module is expecting the environment variable "736915202" to be set. It's not, so it's throwing an exception.

    That seems like a very strange environment variable to have set, though. Is /home/pi/xively/xively.py a third-party module, or did you write it? If you wrote that file, but you expected calling import xively to import a third-party module, you should rename /home/pi/xively/xively.py to something else, and that will probably fix your problem.