2010-04-11 27 views
5

que quieren analizar subtítulos SRT:subtítulos SRT al analizar

1 
    00:00:12,815 --> 00:00:14,509 
    Chlapi, jak to jde s 
    těma pracovníma světlama?. 

    2 
    00:00:14,815 --> 00:00:16,498 
    Trochu je zesilujeme. 

    3 
    00:00:16,934 --> 00:00:17,814 
    Jo, sleduj. 

Cada artículo en la estructura. Con esta regexs:

A:

RE_ITEM = re.compile(r'(?P<index>\d+).' 
    r'(?P<start>\d{2}:\d{2}:\d{2},\d{3}) --> ' 
    r'(?P<end>\d{2}:\d{2}:\d{2},\d{3}).' 
    r'(?P<text>.*?)', re.DOTALL) 

B:

RE_ITEM = re.compile(r'(?P<index>\d+).' 
    r'(?P<start>\d{2}:\d{2}:\d{2},\d{3}) --> ' 
    r'(?P<end>\d{2}:\d{2}:\d{2},\d{3}).' 
    r'(?P<text>.*)', re.DOTALL) 

Y este código:

for i in Subtitles.RE_ITEM.finditer(text): 
    result.append((i.group('index'), i.group('start'), 
      i.group('end'), i.group('text'))) 

con código de BI tener sólo un elemento de array (debido codiciosos . *) y con el código AI tienen 'texto' vacío debido a no-codicioso. *?

Cómo solucionar esto?

Gracias

+0

Cuando leí esto, me di cuenta de que había hecho esto antes, pero no podía recordar cómo. Resulta que lo hice procesalmente, en lugar de usar una expresión regular. La expresión regular es bastante elegante. En caso de que esté interesado, la clase de Python que solía trabajar con subtítulos SRT se puede encontrar en https://svn.jaraco.com/jaraco/python/jaraco.media/jaraco/media/srt.py (tenga en cuenta que ' mero "que importa de jaraco.util es solo 'mero' de la documentación de itertools. –

Respuesta

4

El texto va seguido de una línea vacía o al final del archivo. Así que usted puede utilizar:

r' .... (?P<text>.*?)(\n\n|$)' 
+0

+1 limpio. Y para tener en cuenta el espacio en blanco, puede agregar ... 'r '.... (? P . *?) \ N \ s * \ n'' –

1

Aquí hay un código que tenía por ahí a analizar los archivos SRT:

from __future__ import division 

import datetime 

class Srt_entry(object): 
    def __init__(self, lines): 
     def parsetime(string): 
      hours, minutes, seconds = string.split(u':') 
      hours = int(hours) 
      minutes = int(minutes) 
      seconds = float(u'.'.join(seconds.split(u','))) 
      return datetime.timedelta(0, seconds, 0, 0, minutes, hours) 
     self.index = int(lines[0]) 
     start, arrow, end = lines[1].split() 
     self.start = parsetime(start) 
     if arrow != u"-->": 
      raise ValueError 
     self.end = parsetime(end) 
     self.lines = lines[2:] 
     if not self.lines[-1]: 
      del self.lines[-1] 
    def __unicode__(self): 
     def delta_to_string(d): 
      hours = (d.days * 24) \ 
        + (d.seconds // (60 * 60)) 
      minutes = (d.seconds // 60) % 60 
      seconds = d.seconds % 60 + d.microseconds/1000000 
      return u','.join((u"%02d:%02d:%06.3f" 
           % (hours, minutes, seconds)).split(u'.')) 
     return (unicode(self.index) + u'\n' 
       + delta_to_string(self.start) 
       + ' --> ' 
       + delta_to_string(self.end) + u'\n' 
       + u''.join(self.lines)) 


srt_file = open("foo.srt") 
entries = [] 
entry = [] 
for line in srt_file: 
    if options.decode: 
     line = line.decode(options.decode) 
    if line == u'\n': 
     entries.append(Srt_entry(entry)) 
     entry = [] 
    else: 
     entry.append(line) 
srt_file.close() 
16

Por qué no usar pysrt?

+0

No lo veo bien documentado. –

+0

Mejor enlace a la última versión en http://pypi.python.org/pypi/pysrt – daphshez

+0

Gracias @Daphna! –

1
splits = [s.strip() for s in re.split(r'\n\s*\n', text) if s.strip()] 
regex = re.compile(r'''(?P<index>\d+).*?(?P<start>\d{2}:\d{2}:\d{2},\d{3}) --> (?P<end>\d{2}:\d{2}:\d{2},\d{3})\s*.*?\s*(?P<text>.*)''', re.DOTALL) 
for s in splits: 
    r = regex.search(s) 
    print r.groups() 
1

He aquí un fragmento que escribí que convierte los archivos SRT en los diccionarios:

import re 
def srt_time_to_seconds(time): 
    split_time=time.split(',') 
    major, minor = (split_time[0].split(':'), split_time[1]) 
    return int(major[0])*1440 + int(major[1])*60 + int(major[2]) + float(minor)/1000 

def srt_to_dict(srtText): 
    subs=[] 
    for s in re.sub('\r\n', '\n', srtText).split('\n\n'): 
     st = s.split('\n') 
     if len(st)>=3: 
      split = st[1].split(' --> ') 
      subs.append({'start': srt_time_to_seconds(split[0].strip()), 
         'end': srt_time_to_seconds(split[1].strip()), 
         'text': '<br />'.join(j for j in st[2:len(st)]) 
         }) 
    return subs 

Uso:

import srt_to_dict 
with open('test.srt', "r") as f: 
     srtText = f.read() 
     print srt_to_dict(srtText) 
2

que se hizo bastante frustrado con bibliotecas srt disponible para Python (a menudo porque eran pesados ​​y evitaban el estándar del lenguaje a favor de las clases personalizadas), entonces yo ' He pasado el último año trabajando en mi propia biblioteca srt. Puede obtenerlo al https://github.com/cdown/srt.

Intenté mantenerlo simple y ligero en las clases (excepto en la clase de Subtítulos básicos, que más o menos simplemente almacena los datos del bloque SRT). Puede leer y escribir archivos SRT y convertir los archivos SRT que no cumplen con los requisitos en los compatibles.

Aquí está un ejemplo de uso con su entrada de la muestra:

>>> import srt, pprint 
>>> gen = srt.parse('''\ 
... 1 
... 00:00:12,815 --> 00:00:14,509 
... Chlapi, jak to jde s 
... těma pracovníma světlama?. 
... 
... 2 
... 00:00:14,815 --> 00:00:16,498 
... Trochu je zesilujeme. 
... 
... 3 
... 00:00:16,934 --> 00:00:17,814 
... Jo, sleduj. 
... 
... ''') 
>>> pprint.pprint(list(gen)) 
[Subtitle(start=datetime.timedelta(0, 12, 815000), end=datetime.timedelta(0, 14, 509000), index=1, proprietary='', content='Chlapi, jak to jde s\ntěma pracovníma světlama?.'), 
Subtitle(start=datetime.timedelta(0, 14, 815000), end=datetime.timedelta(0, 16, 498000), index=2, proprietary='', content='Trochu je zesilujeme.'), 
Subtitle(start=datetime.timedelta(0, 16, 934000), end=datetime.timedelta(0, 17, 814000), index=3, proprietary='', content='Jo, sleduj.')] 
+0

¡Eso es perfecto! – Mogsdad

Cuestiones relacionadas