This commit is contained in:
Jamie Hardt
2021-06-03 20:47:27 -07:00
parent 784699050a
commit 55e19a3b8d
5 changed files with 21 additions and 59 deletions

View File

@@ -4,7 +4,7 @@
![Upload Python Package](https://github.com/iluvcapra/ptulsconv/workflows/Upload%20Python%20Package/badge.svg)
# ptulsconv
Read Pro Tools text exports and generate XML, JSON, PDF reports.
Read Pro Tools text exports and generate JSON, PDF reports.
## Quick Example

View File

@@ -1,5 +1,5 @@
from ptulsconv.docparser.ptuls_grammar import protools_text_export_grammar
__version__ = '0.7.0'
__version__ = '0.8.0'
__author__ = 'Jamie Hardt'
__license__ = 'MIT'

View File

@@ -13,30 +13,10 @@ def main():
parser = OptionParser()
parser.usage = "ptulsconv TEXT_EXPORT.txt"
filter_opts = OptionGroup(title='Filtering Options', parser=parser)
# filter_opts.add_option('-i', dest='in_time', help="Don't output events occurring before this timecode.",
# metavar='TC')
# filter_opts.add_option('-o', dest='out_time', help="Don't output events occurring after this timecode.",
# metavar='TC')
filter_opts.add_option('-m', '--include-muted', default=False, action='store_true', dest='include_muted',
help='Include muted clips.')
# filter_opts.add_option('-r', '--reel', dest='select_reel',
# help="Output only events in reel N, and recalculate "
# " start times relative to that reel's start time.",
# default=None, metavar='N')
parser.add_option_group(filter_opts)
parser.add_option('-f', '--format', dest='output_format', metavar='FMT',
choices=['fmpxml', 'json', 'adr', 'csv', 'raw'], default='fmpxml',
help='Set output format, `fmpxml`, `json`, `csv`, or `adr`. Default '
'is `fmpxml`.')
parser.add_option('-x', '--xsl', dest='xslt', metavar='XML', default=None,
help='Output XML with given transform. (Overrides -f to '
'`fmpxml`.)')
choices=['raw', 'json', 'adr'], default='adr',
help='Set output format, `raw`, `json`, `adr`. Default '
'is `adr`.')
warn_options = OptionGroup(title="Warning and Validation Options", parser=parser)
warn_options.add_option('-W', action='store_false', dest='warnings', default=True,
@@ -50,17 +30,14 @@ def main():
informational_options.add_option('--show-available-tags', dest='show_tags',
action='store_true',
default=False, help='Display tag mappings for the FMP XML output style and exit.')
informational_options.add_option('--show-available-transforms', dest='show_transforms',
action='store_true',
default=False, help='Display available built-in XSLT transforms.')
default=False, help='Display tag mappings for the FMP XML '
'output style and exit.')
parser.add_option_group(informational_options)
(options, args) = parser.parse_args(sys.argv)
print_banner_style("%s %s (c) 2020 %s. All rights reserved." % (__name__, __version__, __author__))
print_banner_style("%s %s (c) 2021 %s. All rights reserved." % (__name__, __version__, __author__))
print_section_header_style("Startup")
print_status_style("This run started %s" % (datetime.datetime.now().isoformat()))
@@ -78,23 +55,9 @@ def main():
parser.print_help(sys.stderr)
sys.exit(22)
print_status_style("Input file is %s" % (args[1]))
if options.include_muted:
print_status_style("Muted regions are included.")
else:
print_status_style("Muted regions are ignored.")
try:
output_format = options.output_format
if options.xslt is not None:
output_format = 'fmpxml'
convert(input_file=args[1], output_format=output_format,
include_muted=options.include_muted,
xsl=options.xslt,
progress=False, output=sys.stdout, log_output=sys.stderr,
warnings=options.warnings)
convert(input_file=args[1], output_format=output_format, log_output=sys.stderr, warnings=options.warnings)
except FileNotFoundError as e:
print_fatal_error("Error trying to read input file")
raise e

View File

@@ -139,7 +139,6 @@ def convert(input_file, output_format='fmpxml',
output.write(MyEncoder().encode(session))
else:
compiler = TagCompiler()
compiler.session = session
compiled_events = list(compiler.compile_events())

View File

@@ -1,13 +1,13 @@
import ffmpeg # ffmpeg-python
def create_movie(event):
start = event['Movie.Start_Offset_Seconds']
duration = event['PT.Clip.Finish_Seconds'] - event['PT.Clip.Start_Seconds']
input_movie = event['Movie.Filename']
print("Will make movie starting at {}, dur {} from movie {}".format(start, duration, input_movie))
def export_movies(events):
for event in events:
create_movie(event)
# def create_movie(event):
# start = event['Movie.Start_Offset_Seconds']
# duration = event['PT.Clip.Finish_Seconds'] - event['PT.Clip.Start_Seconds']
# input_movie = event['Movie.Filename']
# print("Will make movie starting at {}, dur {} from movie {}".format(start, duration, input_movie))
#
#
# def export_movies(events):
# for event in events:
# create_movie(event)