我们的『每日一坑』栏目里都是一些练手的小题目,难度不高,适合新手用来熟悉编程。如果想要更复杂的大项目,可以上我们的实验室栏目 lab.crossincode.com 上查看,或者论坛 bbs.crossincode.com 上讨论。
本栏目的往期题目有不少都是数学计算相关的,今天有点不一样,我们来尝试一个图像处理的问题:
在图片上添加文字
效果示例 原图1
效果图1
原图2
效果图2
这个功能有不少实用场景。比如我们经常看到朋友圈的一些个性化海报,上面有你的昵称、头像、分数、留言……都可以通过类似方法实现。而图像处理本身也是 Python 重要应用方向之一。
提示:可以使用 PIL 库(推荐)或 OpenCV 库实现此功能。通过网络搜索,你一定可以找到不少示例代码。
期待各位同学提交解答。
提交代码可以使用 paste.ubuntu.com 或 codeshare.io 等代码分享网站,只需将代码复制上去保存,即可获得一个分享地址,非常方便。
往期问题可通过公众号菜单栏“课外辅导”栏目中进入查看。
【解答】替换文件中的敏感信息
上期的题目相对比较简单,只要熟悉正则表达式就可以很轻松搞定。(所以你们都觉得很简单而不写了么)
不算太严格的匹配:
手机号:1\d{10} 身份证号:\d{18}|\d{17}[xX]
给出 @ChrisYOUNG 同学的代码作为参考:
import re
def remove(data, i, line, regex, left, right):
m = re.search(regex, line)
if m:
digits = m.group(0)
start, end = m.start(0), m.end(0)
data[i] = line[:start+left] + '*' * (right-left+1) + line[start+right+1:]
return True
return False
infile = 'data.txt'
outfile = 'data_proc.txt'
with open(infile) as fr:
data = fr.readlines()
regex_id = '(\d{18}|\d{17}X)'
regex_phone = '1\d{10}'
for i, line in enumerate(data):
status = remove(data, i, line, regex_id, 5, 14)
if not status:
status = remove(data, i, line, regex_phone, 3, 6)
with open(outfile, 'w') as fw:
for line in data:
fw.write(line)
@阳光海岸 同学也提交了解答,不过方法还需改进。
感谢大家的积极参与!期待在下一期中看到你的代码!