mirror of
https://github.com/ytdl-org/youtube-dl
synced 2025-01-04 02:20:10 +09:00
Merge pull request #502 from FiloSottile/new_sanitize_filename
My sanitize_filename proposal
This commit is contained in:
commit
aeca861f22
@ -22,13 +22,13 @@ class TestUtil(unittest.TestCase):
|
|||||||
|
|
||||||
self.assertEqual(sanitize_filename(u'123'), u'123')
|
self.assertEqual(sanitize_filename(u'123'), u'123')
|
||||||
|
|
||||||
self.assertEqual(u'abc_de', sanitize_filename(u'abc/de'))
|
self.assertEqual(u'abc-de', sanitize_filename(u'abc/de'))
|
||||||
self.assertTrue(u'de' in sanitize_filename(u'abc/de'))
|
|
||||||
self.assertFalse(u'/' in sanitize_filename(u'abc/de///'))
|
self.assertFalse(u'/' in sanitize_filename(u'abc/de///'))
|
||||||
|
|
||||||
self.assertEqual(u'abc_de', sanitize_filename(u'abc\\de'))
|
self.assertEqual(u'abc-de', sanitize_filename(u'abc/<>\\*|de'))
|
||||||
self.assertEqual(u'abc_de', sanitize_filename(u'abc\\de'))
|
self.assertEqual(u'xxx', sanitize_filename(u'xxx/<>\\*|'))
|
||||||
self.assertTrue(u'de' in sanitize_filename(u'abc\\de'))
|
self.assertEqual(u'yes no', sanitize_filename(u'yes? no'))
|
||||||
|
self.assertEqual(u'this - that', sanitize_filename(u'this: that'))
|
||||||
|
|
||||||
self.assertEqual(sanitize_filename(u'ä'), u'ä')
|
self.assertEqual(sanitize_filename(u'ä'), u'ä')
|
||||||
self.assertEqual(sanitize_filename(u'кириллица'), u'кириллица')
|
self.assertEqual(sanitize_filename(u'кириллица'), u'кириллица')
|
||||||
|
@ -194,10 +194,20 @@ def timeconvert(timestr):
|
|||||||
def sanitize_filename(s):
|
def sanitize_filename(s):
|
||||||
"""Sanitizes a string so it could be used as part of a filename."""
|
"""Sanitizes a string so it could be used as part of a filename."""
|
||||||
def replace_insane(char):
|
def replace_insane(char):
|
||||||
if char in u' .\\/|?*<>:"' or ord(char) < 32:
|
if char == '?' or ord(char) < 32 or ord(char) == 127:
|
||||||
return '_'
|
return ''
|
||||||
|
elif char == '"':
|
||||||
|
return '\''
|
||||||
|
elif char == ':':
|
||||||
|
return ' -'
|
||||||
|
elif char in '\\/|*<>':
|
||||||
|
return '-'
|
||||||
return char
|
return char
|
||||||
return u''.join(map(replace_insane, s)).strip('_')
|
|
||||||
|
result = u''.join(map(replace_insane, s))
|
||||||
|
while '--' in result:
|
||||||
|
result = result.replace('--', '-')
|
||||||
|
return result.strip('-')
|
||||||
|
|
||||||
def orderedSet(iterable):
|
def orderedSet(iterable):
|
||||||
""" Remove all duplicates from the input iterable """
|
""" Remove all duplicates from the input iterable """
|
||||||
|
Loading…
Reference in New Issue
Block a user