码迷,mamicode.com
首页 > Web开发 > 详细

关于webpy模板自动HTML转义的问题

时间:2017-04-26 12:58:38      阅读:575      评论:0      收藏:0      [点我收藏+]

标签:函数   出错   nbsp   lte   python   from   实现   net   技术   

注意: web.py 将会转义任何任何用到的变量,所以当你将 name 的值设为是一段 HTML 时,它会被转义显示成纯文本。如果要关闭该选项,可以写成 $:name 来代替 $name

如果我们想部分转移,怎么办?

webpy显然提供了转移函数,我们在应用层直接调用就可以了。

from web.net import htmlquote

htmlquote(raw_text)

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

  1. #/usr/bin/python
  2. #coding=utf-8
  3. import HTMLParser
  4. import sys
  5. reload(sys)
  6. sys.setdefaultencoding(‘utf-8‘)
  7. html_parser = HTMLParser.HTMLParser()
  8. title = ‘eclipse功能<template>学习。e.g : 快速在代码中插入时间戳 - SegmentFault‘
  9. newtitle = html_parser.unescape(title)
  10. print newtitle 
  11. 需要载入sys模块,重新设置默认编码为utf8,就不会出错了。不过要处理的内容只不过是一个文章的title部分,而常用的html转义内容也就如下几个
  12. 技术分享

    于是决定使用python的replace功能实现一个简单的转义功能函数,具体如下:

    1. #/usr/bin/python
    2. #coding=utf-8
    3. def replace_html(s):
    4. s = s.replace(‘"‘,‘"‘)
    5. s = s.replace(‘&‘,‘&‘)
    6. s = s.replace(‘&lt;‘,‘<‘)
    7. s = s.replace(‘&gt;‘,‘>‘)
    8. s = s.replace(‘&nbsp;‘,‘ ‘)
    9. s = s.replace(‘ - 361way.com‘,‘‘)
    10. print s
    11. replace_html(title)

    优点就是快速简洁,不依赖于模块,实用时也无需再reload sys模块指定默认编码。

关于webpy模板自动HTML转义的问题

标签:函数   出错   nbsp   lte   python   from   实现   net   技术   

原文地址:http://www.cnblogs.com/soar1688/p/6767810.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!