python生成最小树
这篇文章和大家分享下最小树的生成。
假设一些随机放置的节点,我们希望以最少的线将其连接到一起。节点可能代表许多不同的东西,比如:是我们希望连接在一起的互联网设备。
现在一个平面上有15个随机分散的节点。每个节点都用字母a – z标记,它们是不同的颜色。
了解python异步web框架原理
今天给大家介绍下使用python自带的库如何编写一个异步的server。
使用python将视频转换为字符视频
最早看到字符动画大概是在AB站的弹幕中看到,最近闲来无事就在网上查找了相关的资料,了解下是如何做到的,因为在学python,所以留下此文以便加强记忆。
使用python制作单词拼写检查程序
我想大家在日常中使用英文单词拼写的时候都有过出错的情况,通过这篇文章向各位展示一个简单的拼写检查程序的思路。
centos 7.X安装pip3和python 3.X
python Pillow 实战生成分享图片
废话不多说,今天就带各位使用python的第三方库Pillow自动生成这样的图片。
先简单介绍下Pillow:Pillow是python 3.X上的库,PIL是2.X上的。之所以名字不一样,是因为前者是一群公共代码共享者在后者的基础上更新修改的,因为后者已经很久没更新了。引用下“官方文档”上的说明:
This library provides extensive file format support, an efficient internal representation, and fairly powerful image processing capabilities.The core image library is designed for fast access to data stored in a few basic pixel formats. It should provide a solid foundation for a general image processing tool.
第一步:确认参数
前面已经说过了,一张简单的分享图片包括:一张背景图、一个二维码、一段或多段描述。二维码说白了也就是一个链接。
第二步:背景图获取
from PIL import Image im = Image.open('background.jpg')
这就是Pillow打开图片的最基本的方法,但是这只是读取本地图片,假如我们想要获取网络图片呢?这时候就需要之前提到过的requests库,只需要一句代码即可:
my_response = requests.get(tbpic, stream=True).content im = Image.open(BytesIO(my_response))
注意下:这里的BytesIO是python的自带的内存二进制类型
第三步:转二维码
超链接转二维码很简单,通过qrcode这个第三方库即可,附上代码:
qr_obj = qrcode.make(tburl, border=2) qr_pic = BytesIO() qr_obj.save(qr_pic, format='PNG')
第四步:图片叠加
通过前面的步骤,已经将背景图片和二维码都读入了内存,并以BytesIO的类型存在了。在使用Pillow之前,先理一下要做的事情,将二维码图片放在背景图片上方,这就需要确定二维码放置的位置以及大小。在确定这些后可以就可以使用:
def paste(self, im, box=None, mask=None):
其中im就是需要叠加上去的图片,这里就是二维码图片;
box是在背景图的位置,一个左上右下的四整数元组;
mask是一个模板图像,这个模板图像需要和im大小一样,这个参数暂时用不到;
第五步:添加文字
添加文字需要用到Pillow的ImageDraw模块,直接看代码,我在代码里解释:
from PIL import Image, ImageDraw, ImageFont draw = ImageDraw.Draw(im) #设置字体和大小 _font = ImageFont.truetype(u"txjt.ttf", s35) _color = 'red' #写入文字 #第一个参数xy:距离左边和上边的距离 #第二个参数text:文字内容 #第三个参数font:字体对象_font #第四个参数fill:颜色 draw.text((350, 40), str("显示的文字"), font=_font, fill=_color)
第六步:保存图片
with open('complete.png', 'wb') as f_o: f_o.write(im.getvalue())
注意点:
1.安装pillow可能会因为被墙,可以去git直接下载
2.也许你会遇到:image file is truncated (XX bytes not processed) 这样的错误
需要在开始import的时候加上
from PIL import ImageFile ImageFile.LOAD_TRUNCATED_IMAGES = True
3.文字需要用用str进行编码转换
最后附上粗糙的效果图:
版权所属,如需转载,请注明出处:搜闲鱼
淘宝客python SDK 3.X升级
这里稍微介绍下:淘宝客大概就是帮商家进行推广的群体称谓,其中商家会在商品价格中支出一部分给推广者作为佣金,相比以前商家花钱雇人刷单的方式,商家把刷单的开销分摊为淘宝客的佣金和买家的优惠,算一种三赢的方式吧。
在阿里后台里看到了有python的 API SDK可以使用,很是开心,立马下载来了开始用,结果sample根本跑不起来。
一看错误……这貌似是2.X的语法,再去看说明:支持python 2.7以上。妈蛋,3.X也是2.7以上,但是却不支持,还以为自己下载错了,工单咨询后确认不支持3.X。于是只能自己来升级了。
- 在3中,用int替代了long,所以:
P_TIMESTAMP: str(int(time.time() * 1000)),
- 用items替代iteritems:
for key, value in application_parameter.items():
- 查阅资料,发现有人说到dict methods dict.keys(), dict.items() and dict.values() return “views” instead of lists.这样就显而易见知道怎么改了:
keys = sorted(keys)
- 英文意思很明确,unicode对象在哈希之前必须进行编码转换,想起之前又看到过中文字符在python中是以unicode存在的,所以:
sign = hashlib.md5(parameters.encode("utf-8")).hexdigest().upper()
- 这是花费时间最长的一个错误。首先,直接看最后,错误在soket.py里,心凉了半截,难道这里的调用都不一样了,再网上看又是python 3.X的http模块,去百度了半天也没有发现类似的错误,只能自己硬着头皮去看模块,功夫不负有心人,其实也很简单,在类HTTPConnection的初始化函数是这样定义的:
connection = httplib.HTTPConnection(self.__domain, self.__port, timeout)
比较下参数发现,python 2比3多了一个参数,去掉即可:
connection = httplib.HTTPConnection(self.__domain, self.__port, timeout)
这个错误主要是是报错的地方和修改的地方不在一起,所以很难插出原因。
- 官方文档是这样解释的:urllib has been split up in Python 3. The urllib.urlencode() function is now urllib.parse.urlencode(), and the urllib.urlopen() function is now urllib.request.urlopen()
url = N_REST + "?" + urllib.parse.urlencode(sys_parameters)
- 这个错误是在API调用出异常的时候暴露出来的。原因前面已经提到了,稍微查了下替代的方法:
if "error_response" in jsonobj:
到此为止,SDK的python 3.X升级就算告一段落了,看注释这个SDK是2012年写的,年代久远。3替代2是必然的,所以我这样的新手直接从3开始学,通过这次也学到了不少2的语法,虽然用不到,但是相信加深了对python的理解。
以上!
版权所属,如需转载,请注明出处:搜闲鱼
django打造微信个人公众号
现在自媒体很是火爆,其中腾讯的微信公众号作为其中一员,也是占有一席之地。本着学习python的心理下,想要自己搭建一次公众号开发后台。
通过xpath和beautifulsoup爬取游戏币实时价格
有个朋友是做的是一种不可描述的工作,需要经常上这么一个网站:http://b2b.1771.com/shouquotation.html