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

View File

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

View File

@@ -13,30 +13,10 @@ def main():
parser = OptionParser() parser = OptionParser()
parser.usage = "ptulsconv TEXT_EXPORT.txt" 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', parser.add_option('-f', '--format', dest='output_format', metavar='FMT',
choices=['fmpxml', 'json', 'adr', 'csv', 'raw'], default='fmpxml', choices=['raw', 'json', 'adr'], default='adr',
help='Set output format, `fmpxml`, `json`, `csv`, or `adr`. Default ' help='Set output format, `raw`, `json`, `adr`. Default '
'is `fmpxml`.') 'is `adr`.')
parser.add_option('-x', '--xsl', dest='xslt', metavar='XML', default=None,
help='Output XML with given transform. (Overrides -f to '
'`fmpxml`.)')
warn_options = OptionGroup(title="Warning and Validation Options", parser=parser) warn_options = OptionGroup(title="Warning and Validation Options", parser=parser)
warn_options.add_option('-W', action='store_false', dest='warnings', default=True, warn_options.add_option('-W', action='store_false', dest='warnings', default=True,
@@ -46,21 +26,18 @@ def main():
informational_options = OptionGroup(title="Informational Options", parser=parser, informational_options = OptionGroup(title="Informational Options", parser=parser,
description='Print useful information and exit without processing ' description='Print useful information and exit without processing '
'input files.') 'input files.')
informational_options.add_option('--show-available-tags', dest='show_tags', informational_options.add_option('--show-available-tags', dest='show_tags',
action='store_true', action='store_true',
default=False, help='Display tag mappings for the FMP XML output style and exit.') 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.')
parser.add_option_group(informational_options) parser.add_option_group(informational_options)
(options, args) = parser.parse_args(sys.argv) (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_section_header_style("Startup")
print_status_style("This run started %s" % (datetime.datetime.now().isoformat())) print_status_style("This run started %s" % (datetime.datetime.now().isoformat()))
@@ -78,23 +55,9 @@ def main():
parser.print_help(sys.stderr) parser.print_help(sys.stderr)
sys.exit(22) 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: try:
output_format = options.output_format output_format = options.output_format
if options.xslt is not None: convert(input_file=args[1], output_format=output_format, log_output=sys.stderr, warnings=options.warnings)
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)
except FileNotFoundError as e: except FileNotFoundError as e:
print_fatal_error("Error trying to read input file") print_fatal_error("Error trying to read input file")
raise e raise e

View File

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

View File

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