J'essaye de contrôler un Keithley 2410 via python sur une machine linux x86_64 (CentOS 7). J'utilise python 2.7.5, NI-VISA 16 et PyVISA 1.8. Le Keithley est connecté à l'ordinateur via un câble RS232-USB et il est configuré pour la communication RS232 (avec les paramètres: baud 57600, bits 8, parité none, terminator, flow-ctrl none). Lorsque je tente d'interroger le Keithley je reçois une erreur de délai d'attente, comme indiqué ci-dessous:Keithley 2410 et PyVISA - VI_ERROR_TMO: Expiration du délai avant la fin de l'opération
>>> import visa
>>> rm = visa.ResourceManager()
>>> print(rm.list_resources())
(u'ASRL1::INSTR', u'ASRL2::INSTR')
>>> keithley = rm.open_resource("ASRL2::INSTR")
>>> print(keithley.query('*IDN?'))
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
File "/usr/lib/python2.7/site-packages/pyvisa/resources/messagebased.py", line 407, in query
return self.read()
File "/usr/lib/python2.7/site-packages/pyvisa/resources/messagebased.py", line 332, in read
message = self.read_raw().decode(enco)
File "/usr/lib/python2.7/site-packages/pyvisa/resources/messagebased.py", line 306, in read_raw
chunk, status = self.visalib.read(self.session, size)
File "/usr/lib/python2.7/site-packages/pyvisa/ctwrapper/functions.py", line 1582, in read
ret = library.viRead(session, buffer, count, byref(return_count))
File "/usr/lib/python2.7/site-packages/pyvisa/ctwrapper/highlevel.py", line 188, in _return_handler
raise errors.VisaIOError(ret_value)
pyvisa.errors.VisaIOError: VI_ERROR_TMO (-1073807339): Timeout expired before operation completed.