python给excel添加超链接_python-docx表格内Cell添加超链接

def add_hyperlink(paragraph, url, text):

"""

A function that places a hyperlink within a paragraph object.

:param paragraph: The paragraph we are adding the hyperlink to.

:param url: A string containing the required url

:param text: The text displayed for the url

:return: The hyperlink object

"""

# This gets access to the document.xml.rels file and gets a new relation id value

part = paragraph.part

r_id = part.relate_to(url, docx.opc.constants.RELATIONSHIP_TYPE.HYPERLINK, is_external=True)

# Create the w:hyperlink tag and add needed values

hyperlink = docx.oxml.shared.OxmlElement('w:hyperlink')

hyperlink.set(docx.oxml.shared.qn('r:id'), r_id, )

# Create a w:r element

new_run = docx.oxml.shared.OxmlElement('w:r')

# Create a new w:rPr element

rPr = docx.oxml.shared.OxmlElement('w:rPr')

# Join all the xml elements together add add the required text to the w:r element

new_run.append(rPr)

new_run.text = text

#new_run.font.color.rgb = RGBColor(0,0,255)

hyperlink.append(new_run)

paragraph._p.append(hyperlink)

#paragraph.text = text

r = paragraph.add_run()

r._r.append(hyperlink)

# A workaround for the lack of a hyperlink style (doesn't go purple after using the link)

# Delete this if using a template that has the hyperlink style in it

#r.font.color.theme_color = MSO_THEME_COLOR_INDEX.HYPERLINK

r.font.color.rgb = RGBColor(0,0,255)

r.font.underline = True

return hyperlink

--------------------------------------------------------------------------------------------------

使用时调用方式:

paragraph = row_cells[i].paragraphs[0]

add_hyperlink(paragraph, hyperlink, text)

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值