瀏覽代碼

Merge pull request #12906 from Tithen-Firion/clean-html-fix

[utils] Fix inconsistent output of clean_html
Yen Chi Hsuan 8 年之前
父節點
當前提交
d19093bd50
共有 2 個文件被更改,包括 3 次插入2 次删除
  1. 1 0
      test/test_utils.py
  2. 2 2
      youtube_dl/utils.py

+ 1 - 0
test/test_utils.py

@@ -899,6 +899,7 @@ class TestUtil(unittest.TestCase):
     def test_clean_html(self):
     def test_clean_html(self):
         self.assertEqual(clean_html('a:\nb'), 'a: b')
         self.assertEqual(clean_html('a:\nb'), 'a: b')
         self.assertEqual(clean_html('a:\n   "b"'), 'a:    "b"')
         self.assertEqual(clean_html('a:\n   "b"'), 'a:    "b"')
+        self.assertEqual(clean_html('a<br>\xa0b'), 'a\nb')
 
 
     def test_intlist_to_bytes(self):
     def test_intlist_to_bytes(self):
         self.assertEqual(
         self.assertEqual(

+ 2 - 2
youtube_dl/utils.py

@@ -421,8 +421,8 @@ def clean_html(html):
 
 
     # Newline vs <br />
     # Newline vs <br />
     html = html.replace('\n', ' ')
     html = html.replace('\n', ' ')
-    html = re.sub(r'\s*<\s*br\s*/?\s*>\s*', '\n', html)
-    html = re.sub(r'<\s*/\s*p\s*>\s*<\s*p[^>]*>', '\n', html)
+    html = re.sub(r'(?u)\s*<\s*br\s*/?\s*>\s*', '\n', html)
+    html = re.sub(r'(?u)<\s*/\s*p\s*>\s*<\s*p[^>]*>', '\n', html)
     # Strip html tags
     # Strip html tags
     html = re.sub('<.*?>', '', html)
     html = re.sub('<.*?>', '', html)
     # Replace html entities
     # Replace html entities