一行Python代码过滤标点符号等特殊字符


Posted in Python onAugust 12, 2019

很多时候我们需要过滤掉标点符号等特殊字符,网上虽然有一堆的方法,但是都没有找到一个非常满意的,有些过滤不了中文的标点符号,有些过滤不了英文的标点符号,有些过滤不全。

最后通过查看正则表达式文档,发现一个高效的办法,一行代码就能搞定:

def replace_all_blank(value):
  """
  去除value中的所有非字母内容,包括标点符号、空格、换行、下划线等
  :param value: 需要处理的内容
  :return: 返回处理后的内容
  """
  # \W 表示匹配非数字字母下划线
  result = re.sub('\W+', '', value).replace("_", '')
  print(result)
  return result

其中用到了 Python 的 re 模块, re 模块里面包含了所有的正则表达式的应用。代码里面有几个点:

\W

测试一下:

replace_all_blank("Powe, on;the 2333, 。哈哈 !!看看可以吗?一行代码就可以了!^_^")

输出结果:

Poweonthe2333哈哈看看可以吗一行代码就可以了

一行代码搞定!Perfect!

最后推荐大家官网 re 模块的正则表达式文档地址:

https://docs.python.org/zh-cn/3.6/library/re.html

知识点扩展:

python过滤中英文标点符号

import re
# 过滤不了\\ \ 中文()还有————
r1 = u'[a-zA-Z0-9'!"#$%&\'()*+,-./:;<=>?@,。?★、…【】《》?“”‘'![\\]^_`{|}~]+'#用户也可以在此进行自定义过滤字符
# 者中规则也过滤不完全
r2 = "[\s+\.\!\/_,$%^*(+\"\']+|[+——!,。?、~@#¥%……&*()]+"
# \\\可以过滤掉反向单杠和双杠,/可以过滤掉正向单杠和双杠,第一个中括号里放的是英文符号,第二个中括号里放的是中文符号,第二个中括号前不能少|,否则过滤不完全
r3 = "[.!//_,$&%^*()<>+\"'?@#-|:~{}]+|[——!\\\\,。=?、:“”‘'《》【】¥……()]+"
# 去掉括号和括号内的所有内容
r4 = "\\【.*?】+|\\《.*?》+|\\#.*?#+|[.!/_,$&%^*()<>+""'?@|:~{}#]+|[——!\\\,。=?、:“”‘'¥……()《》【】]"
text = "\崔芸,\\我爱=+你!【我//""们】~————结/婚'吧::!这.!!_#??()个‘'“”¥$主|意()不错......!"
print(re.sub(r1, , '', text))

总结

以上所述是小编给大家介绍的一行代码Python过滤标点符号等特殊字符,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!
如果你觉得本文对你有帮助,欢迎转载,烦请注明出处,谢谢!

Python 相关文章推荐
python定时器使用示例分享
Feb 16 Python
python调用短信猫控件实现发短信功能实例
Jul 04 Python
详细解读Python中的__init__()方法
May 02 Python
Python采用Django制作简易的知乎日报API
Aug 03 Python
Python错误: SyntaxError: Non-ASCII character解决办法
Jun 08 Python
python中数据爬虫requests库使用方法详解
Feb 11 Python
python中字符串比较使用is、==和cmp()总结
Mar 18 Python
对python中字典keys,values,items的使用详解
Feb 03 Python
Python 合并多个TXT文件并统计词频的实现
Aug 23 Python
Django 路由层URLconf的实现
Dec 30 Python
浅谈keras中的目标函数和优化函数MSE用法
Jun 10 Python
Python爬虫之Selenium多窗口切换的实现
Dec 04 Python
一篇文章弄懂Python中的可迭代对象、迭代器和生成器
Aug 12 #Python
Django认证系统实现的web页面实现代码
Aug 12 #Python
django 自定义过滤器(filter)处理较为复杂的变量方法
Aug 12 #Python
django-filter和普通查询的例子
Aug 12 #Python
利用python实现汉字转拼音的2种方法
Aug 12 #Python
python面向对象 反射原理解析
Aug 12 #Python
Python中正反斜杠(‘/’和‘\’)的意义与用法
Aug 12 #Python
You might like
php smarty模版引擎中的缓存应用
2009/12/11 PHP
php守护进程 加linux命令nohup实现任务每秒执行一次
2011/07/04 PHP
PHP基础陷阱题(变量赋值)
2012/09/12 PHP
PHP中$_SERVER的详细参数与说明介绍
2013/10/26 PHP
php实现将字符串按照指定距离进行分割的方法
2015/03/14 PHP
一组JS创建和操作表格的函数集合
2009/05/07 Javascript
window.open关于浏览器拦截问题分析及解决方法
2013/02/05 Javascript
JS去除数组重复值的五种不同方法
2013/09/06 Javascript
jquery实现弹出层完美居中效果
2014/03/03 Javascript
node.js中RPC(远程过程调用)的实现原理介绍
2014/12/05 Javascript
JS中使用apply方法通过不同数量的参数调用函数的方法
2016/05/31 Javascript
js设置和获取自定义属性的方法
2016/10/20 Javascript
JS树形菜单组件Bootstrap TreeView使用方法详解
2016/12/21 Javascript
Vue axios 中提交表单数据(含上传文件)
2017/07/06 Javascript
微信小程序scroll-view组件实现滚动动画
2018/01/31 Javascript
vue组件name的作用小结
2018/05/23 Javascript
vuex存取值和映射函数使用说明
2020/07/24 Javascript
Python函数学习笔记
2008/10/07 Python
Python中用max()方法求最大值的介绍
2015/05/15 Python
Python实现HTTP协议下的文件下载方法总结
2016/04/20 Python
TensorFlow模型保存/载入的两种方法
2018/03/08 Python
解决Python2.7读写文件中的中文乱码问题
2018/04/12 Python
python学习笔记--将python源文件打包成exe文件(pyinstaller)
2018/05/26 Python
python矩阵转换为一维数组的实例
2018/06/05 Python
在PyCharm的 Terminal(终端)切换Python版本的方法
2019/08/02 Python
python 有效的括号的实现代码示例
2019/11/11 Python
Django中FilePathField字段的用法
2020/05/21 Python
快速创建python 虚拟环境
2020/11/28 Python
解决HTML5中滚动到底部的事件问题
2019/08/22 HTML / CSS
客服端调用EJB对象的几个基本步骤
2012/01/15 面试题
95%的面试官都会问到的50道Java线程题,附答案
2012/08/03 面试题
公司周年庆典邀请函
2014/01/12 职场文书
餐厅经理岗位职责和岗位目标
2014/02/13 职场文书
学术诚信承诺书
2014/05/26 职场文书
python解决12306登录验证码的实现
2021/04/18 Python
Spring boot admin 服务监控利器详解
2022/08/05 Java/Android