python生成最小树

这篇文章和大家分享下最小树的生成。
假设一些随机放置的节点,我们希望以最少的线将其连接到一起。节点可能代表许多不同的东西,比如:是我们希望连接在一起的互联网设备。
现在一个平面上有15个随机分散的节点。每个节点都用字母a – z标记,它们是不同的颜色。 阅读全文

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。于是只能自己来升级了。

  1. 在3中,用int替代了long,所以:
    
    P_TIMESTAMP: str(int(time.time() * 1000)),
    
    
  2. 用items替代iteritems:
    for key, value in application_parameter.items():
    
  3. 查阅资料,发现有人说到dict methods dict.keys(), dict.items() and dict.values() return “views” instead of lists.这样就显而易见知道怎么改了:
    
    keys = sorted(keys)
    
    
  4. 英文意思很明确,unicode对象在哈希之前必须进行编码转换,想起之前又看到过中文字符在python中是以unicode存在的,所以:
    
    sign = hashlib.md5(parameters.encode("utf-8")).hexdigest().upper()
    
    
  5. 这是花费时间最长的一个错误。首先,直接看最后,错误在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)
    
    

    这个错误主要是是报错的地方和修改的地方不在一起,所以很难插出原因。

  6. 官方文档是这样解释的: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)
  7. 这个错误是在API调用出异常的时候暴露出来的。原因前面已经提到了,稍微查了下替代的方法:
    
    if "error_response" in jsonobj:
    
    

    到此为止,SDK的python 3.X升级就算告一段落了,看注释这个SDK是2012年写的,年代久远。3替代2是必然的,所以我这样的新手直接从3开始学,通过这次也学到了不少2的语法,虽然用不到,但是相信加深了对python的理解。

    以上!

    版权所属,如需转载,请注明出处:搜闲鱼