3

所以我有一个看起来像这样的文件:

#!/usr/bin/python
import MySQLdb
import subprocess
from subprocess import call
import re

conx = MySQLdb.connect (user = 'root', passwd = '******', db = 'vaxijen_antigens')
cursor = conx.cursor()
cursor.execute('select * from sequence')
row = cursor.fetchall()

f = open('/home/rv/ncbi-blast-2.2.23+/db/vdatabase.fasta', 'w')

for i in row:
    f.write('>'+i[0].strip()+'\n')
    s = re.sub(r'[^\w]','',str(i[1]))
    s = ''.join(s)
    for k in range(0, len(s), 60):
        f.write('%s\n' % (s[k:k+60]))
    f.write('\n')

f.close()

subprocess.call(['formatdb', '-p', 'T', '-i', r'/home/rv/ncbi-blast-2.2.23+/db/vdatabase.fasta'])

该文件从命令行运行没有问题,但是当我尝试使用 crontab 运行它时,出现此错误:

  File "/home/rv/ncbi-blast-2.2.23+/db/formatdb.py", line 29, in <module>
    subprocess.call(['formatdb', '-p', 'T', '-i',
r'/home/rv/ncbi-blast-2.2.23+/db/vdatabase.fasta'])
OSError: [Errno 2] No such file or directory

我不明白,该文件存在于该目录中,我已经检查了两次和三次。我尝试将文件路径转换为原始字符串,因此路径前的小写“r”但也没有这样做。

4

2 回答 2

5

我怀疑它在您的子进程调用中抱怨“formatdb”的路径。尝试将其更改为完整路径:

subprocess.call(['/home/path/formatdb', ...])
于 2010-08-11T17:06:36.237 回答
3

cron 守护进程通常只提供非常有限的 PATH。要么在 crontab 中放置一个更完整的 PATH,要么在 Python 代码中使用完整的路径名。

于 2010-08-11T17:05:23.353 回答