我有一个带有一些基本文字的文本文件:
For more information on this topic, go to (http://moreInfo.com)
This tool is available from (https://www.someWebsite.co.uk)
Contacts (https://www.contacts.net)
我希望这些网址在QTextBrowser中显示为超链接,这样点击后,网络浏览器就会打开并加载网站。我见过this post使用:
<a href="http://foo">Bar</a>
但由于任何人都可以编辑文本文件(即它们可能包含不提供网址的文本),如果这些地址(如果有的话)可以在添加到文本浏览器之前自动进行超链接,我希望如此
这是我阅读文本文件的方式:
def info(self):
text_browser = self.dockwidget.text_browser
file_path = 'path/to/text.txt'
f = open(file_path, 'r')
text = f.read()
text_browser.setText(text)
text_browser.setOpenExternalLinks(True)
self.dockwidget.show()
修改
取得了一些进展并设法使用超链接(假设链接在括号内):
import re
def info(self):
text_browser = self.dockwidget.text_browser
file_path = 'path/to/text.txt'
f = open(about_file_path, 'r')
text = f.read()
urls = re.findall('http[s]?://(?:[a-zA-Z]|[0-9]|[$-_@.&+]|[!*\(\),]|(?:%[0-9a-fA-F][0-9a-fA-F]))+', text)
for x in urls:
if x in text:
text = text.replace(x, x.replace('http', '<a href="http').replace(')', '">') + x + '</a>')
textBrowser.setHtml(text)
textBrowser.setOpenExternalLinks(True)
self.dockwidget.show()
但是,它全部出现在一行中,而不是与文本文件中的格式相同。我怎么能解决这个问题?
答案 0 :(得分:1)
正确匹配网址比您当前的解决方案所暗示的更复杂。有关问题的完整细分,请参阅:What is the best regular expression to check if a string is a valid URL? 。
另一个问题更容易解决。要保留换行符,您可以使用:
text = '<br>'.join(text.splitlines())