Advertisement
Not a member of Pastebin yet?
Sign Up,
it unlocks many cool features!
- python_string = """
- result_one = len([1,2,3])
- print result_one
- result_two = range(r)
- print result_two
- result_three = max(result_two)
- print "done"
- """
- exec(python_string)
- 3
- [0, 1, 2]
- done
- '3'
- '[0, 1, 2]'
- 'done'
- result_one = len([1,2,3])
- print result_one
- result_two = range(r)
- print result_two
- result_three = max(result_two)
- print "done"
- import sys
- import inspect
- python_string_as_dictionary = dict(enumerate(open(inspect.getfile(inspect.currentframe()), 'r+').read().split("n")))
- #>>{0: 'import sys', 1: 'import inspect', 2: '', 3: 'f_dict = dict(enumerate(open(inspect.getfile(inspect.currentframe()), 'r+').read().split("\n")))', 4: 'print f_dict', 5: 'class SetTrace(object):', 6: ' def __init__(self, func):', 7: ' self.func = func', 8: '', 9: ' def __enter__(self):', 10: ' sys.settrace(self.func)', 11: ' return self', 12: '', 13: ' def __exit__(self, ext_type, exc_value, traceback):', 14: ' sys.settrace(None)', 15: '', 16: '', 17: 'def monitor(frame, event, arg):', 18: 'tprint event', 19: 'tprint "line: {}".format(str(frame.f_lineno))', 20: 'tif event == "line" :', 21: 'ttreturn monitor', 22: '', 23: 'python_string = """', 24: 'result_one = len([1,2,3])', 25: 'print result_one', 26: 'result_two = range(result_one)', 27: 'print result_two', 28: 'result_three = max(result_two)', 29: 'print "done"', 30: '"""', 31: 'with SetTrace(monitor):', 32: ' exec(python_string)', 33: '', 34: '', 35: ''}
- class SetTrace(object):
- def __init__(self, func):
- self.func = func
- def __enter__(self):
- sys.settrace(self.func)
- return self
- def __exit__(self, ext_type, exc_value, traceback):
- sys.settrace(None)
- def monitor(frame, event, arg):
- print "line: {}".format(str(frame.f_lineno))
- print python_string_as_dictionary[frame.f_lineno-1].strip()
- if event == "line" :
- return monitor
- python_string = """
- result_one = len([1,2,3])
- print result_one
- result_two = range(result_one)
- print result_two
- result_three = max(result_two)
- print "done"
- """
- with SetTrace(monitor):
- exec(python_string)
- import subprocess as subp
- python_string = """
- result_one = len([1,2,3])
- print result_one
- result_two = range(result_one)
- print result_two
- result_three = max(result_two)
- print result_three
- print "done"
- """
- proc = subp.Popen(['python', '-'], stdin=subp.PIPE,
- stdout=subp.PIPE, stderr=subp.STDOUT)
- proc.stdin.write(python_string)
- proc.stdin.close()
- for line in proc.stdout:
- print 'out: {}'.format(line.strip())
- proc.wait()
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement