From 092af159015cdb94b56e06c4b651a8ffcf36663e Mon Sep 17 00:00:00 2001 From: Trond Linjordet Date: Wed, 20 Sep 2023 14:05:45 +0200 Subject: [PATCH] Add changes to achieve progress described The progress with Tutorial 4 is detailed in issue #176 https://github.com/hjkgrp/molSimplify/issues/176 --- molSimplify/Classes/globalvars.py | 13 ++++++------- molSimplify/Scripts/dbinteract.py | 10 ++++++---- 2 files changed, 12 insertions(+), 11 deletions(-) diff --git a/molSimplify/Classes/globalvars.py b/molSimplify/Classes/globalvars.py index e11064fc..4441f9fc 100644 --- a/molSimplify/Classes/globalvars.py +++ b/molSimplify/Classes/globalvars.py @@ -458,13 +458,12 @@ def mybash(cmd): """ p = subprocess.Popen( cmd, shell=True, stdout=subprocess.PIPE, stderr=subprocess.STDOUT) - stdout = [] - while True: - line = p.stdout.readline() - stdout.append(line) - if line == '' and p.poll() is not None: - break - return ''.join(stdout) + stdout, stderr = p.communicate() + lines = stdout.decode('utf-8').splitlines() + lines = [line+"\n" for line in lines if line !=""] + #print(cmd) + #print(''.join(lines)) + return ''.join(lines) # Defines global variables used throughout the code diff --git a/molSimplify/Scripts/dbinteract.py b/molSimplify/Scripts/dbinteract.py index 488a04a3..f031ee50 100644 --- a/molSimplify/Scripts/dbinteract.py +++ b/molSimplify/Scripts/dbinteract.py @@ -162,13 +162,13 @@ def getsimilar(smi, nmols, dbselect, finger, squery, args): print(('database set up :' + str(dbsdf) + ' || ' + str(dbfs))) print(('Finding results similar, comparing to ' + smi)) - obab = 'babel' + obab = 'obabel' # babel -> obabel if dbfs and args.dbfs: com = obab + ' ' + dbfs + ' ' + 'simres.smi -d -xf' + \ finger + ' -s"' + smi + '" -al' + nmols else: mybash(obab + ' -isdf ' + dbsdf + ' -osdf -O tmp.sdf -d') - com = obab + ' tmp.sdf simres.smi -xf' + finger + ' -s"' + smi + '"' + com = obab + ' tmp.sdf -O simres.smi -xf' + finger + ' -s"' + smi + '"' # babel -> obabel # perform search using bash commandline print('Performing substructure search:') print(('running: ' + str(com))) @@ -306,7 +306,7 @@ def checkels(fname, allowedels): # @param outf Filename containing SMILES strings to be processed # @param n Number of dissimilar molecules required def dissim(outf, n): - obab = 'babel' + obab = 'obabel' # babel -> obabel # clone hitlist file hit_list_path = "hitlist.smi" @@ -317,7 +317,7 @@ def dissim(outf, n): f.writelines(smiles_list) # generate fs of original hit list - mybash(obab + ' -ismi ' + hit_list_path + ' -osdf tmp.sdf') + mybash(obab + ' -ismi ' + hit_list_path + ' -osdf -O tmp.sdf') # babel -> obabel mybash(obab + ' tmp.sdf -ofs') # number of hits numcpds = mybash('obabel tmp.sdf -onul') @@ -553,6 +553,8 @@ def dbsearch(rundir, args, globs): shutil.copy('simres.smi', outf) except FileNotFoundError: pass + except shutil.SameFileError: # babel -> obabel + pass # babel -> obabel if args.debug: print(('after similarity search, outf is ' + str(outputf)))