Python每日一练(1)
这两天在做Python的每日一练,感觉收获颇丰,所以来记录分享一下,一共做了三个,涉及socket,PIL,pymysql三个库,另外终于开始了Flask框架的学习,后续也会做出一些分析
第一个是一个简单的socket练习,主要就是实现两个终端之间的交互,此次原本想是服务端脚本放在虚拟机里,然后主机当作客户端实现交互,可是,所有端口都放行,防火墙也设置通过之后,还是无法实现交互,总是被拒绝连接,之后只好在一台机子上进行测试,遂成功。
下面简单记录一下这次的socket(安全套接字)的基本步骤:
首先就是要有两个端的脚本,一个server端的,一个client端的。
server端主要有以下功能:
1、设置服务端口,并与主机绑定(突然想到可能由于没有设置地址的原因导致主机无法ip访问)
2、反馈信息,当客户端访问时
client端主要是以下功能:
1、向服务端发送请求访问信息
2、获取服务端反馈信息
代码仍需改善这次就不贴出了丢人了,大致实现效果如下
第二个是实现在图片的右上角添加文字,主要涉及到PIL库的一些相关模块,首先PIL是专门用于对图片进行操作的库,所以加强对其掌握还是很有必要的,闲话不多说,来看一下这个题目:
1、想要实现在图片上写文字,主要是这样一个思路,实例化一个图片对象,然后选择填充文字的字体和颜色进行填充即可
注:对于定位到右上角这样的问题,我的理解是这样的,首先一个图片的坐标,从左上角开始定位是(0,0),而偏移符合我们高中数学函数平移的规则,即左加右减原则,所以移到右上角只要在宽度的基础上减去一个值即可
下面是代码示例和最终效果截图:
# -*- coding:utf-8 -*-
# 每日一练:将你的 QQ 头像(或者微博头像)右上角加上红色的数字
# 类似于微信未读信息数量那种提示效果。
# Author : Konmu from PIL import Image,ImageFont,ImageDraw def Image_fill(im_file,num):
im=Image.open(im_file)
width,height=im.size
font_type=ImageFont.truetype('C:/Windows/fonts/字酷堂海藏楷体.ttf',50)
fill_color='steelblue'
draw=ImageDraw.ImageDraw(im)
draw.text((width-50,0),str(num),fill=fill_color,font=font_type)
#图片坐标左上角开始为原点,平移符合了左加右减原则
#故到达右上角即减去一个偏移量即可
save_file='C:/Users/xxx/Desktop/output.jpg'
im.save(save_file) if __name__=='__main__':
Image_fill('C:/Users/xxx/Desktop/少天.jpg',21)
最终效果:
第三个是实现生成20个随机激活码并保存至关联性数据库mysql中,对于python对数据库的操作俗说君也是第一次接触故而这次也是简单的学习了一下,后续还需加强练习。
分析一下这个问题,首先生成激活码这种事并不难,我们平时玩游戏时领取礼包的一些激活码可以发现大多都是一些字母和数字的组合,所以我们只要生成一些类似这样形式的字符串即可模拟出激活码的效果。剩下来就是解决他的存储问题,python中提供了pymysql库帮助我们和mysql数据库进行连接,我们这里也采用这个库来实现我们的目标。
下面先来看几个本次会用到的基本的mysql语句,其他详细的语法请自行查阅:
create database test; #创建数据库
create table gencode(id int auto_increment primary key,value varchar(20)); #创建数据表,id 是采用的自增长型
insert into gencode(id,value) values (1,'GB0XRF2boYF2BPEp46l5') #向表中插入数据,这里要注意数据的类型
drop table if exists test; #删除已存在的表
接下来看看pymysql的相关语句:
db=pymysql.connect('localhost','user','password','table') #连接本地数据库,其中用户,密码和数据库填写自己的信息即可
cursor=db.cursor() #创建cursor对象
cursor.execute(sql) #执行相关sql语句
db.commit() #提交数据到数据库
db.close() #关闭数据库
下面来看看完整代码和最终效果:
#!/user/bin/python3
#-*-coding:utf-8 *-*
#Author:konmu
#生成激活码(或者优惠券),使用 Python 如何生成20个激活码(或者优惠券)?将生成的激活码(或者优惠券)保存到 MySQL 关系型数据库中。 import pymysql
import random,string def genkey():
getChars = string.ascii_letters+string.digits
generate = "".join([random.choice(getChars)for i in range(20)])
return(generate) def table_insert(cursor, db):
for i in range(20):
sql = "insert into gencode (id,value) values ({0},'{1}')".format("null", genkey())#向表中插入数据
cursor.execute(sql)
db.commit() if __name__=='__main__':
db = pymysql.connect("localhost", "root", "", "test")#本次测试使用的数据库是test
cursor = db.cursor()#创建cursor对象
cursor.execute("drop table if exists gencode")#删除gencode表如果已存在的话
sql = "create table generateCodes(id int auto_increment primary key, value varchar(50))"#创建表
try:
cursor.execute(sql)
db.commit()
except:
db.rollback()
genkey()
table_insert(cursor, db)
db.close()
最终效果:
Python每日一练(1)的更多相关文章
- python每日一练:0007题
第 0007 题: 有个目录,里面是你自己写过的程序,统计一下你写过多少行代码.包括空行和注释,但是要分别列出来. # -*- coding:utf-8 -*- import os def count ...
- [python每日一练]--0012:敏感词过滤 type2
题目链接:https://github.com/Show-Me-the-Code/show-me-the-code代码github链接:https://github.com/wjsaya/python ...
- Python 每日一练 | Flask 实现半成品留言板
留言板Flask实现 引言 看了几天网上的代码,终于写出来一个半成品的Flask的留言板项目,为什么说是半成品呢?因为没能实现留言板那种及时评论刷新的效果,可能还是在重定向上有问题 或者渲染写的存在问 ...
- Python 每日一练(5)
引言 Python每日一练又开始啦,今天的专题和Excel有关,主要是实现将txt文本中数据写入到Excel中,说来也巧,今天刚好学校要更新各团支部的人员信息,就借此直接把事情做了 主要对于三种数据类 ...
- Python 每日一练(4)
引言 今天继续是python每日一练的几个专题,主要涵盖简单的敏感词识别以及图片爬虫 敏感词识别 这个敏感词的识别写的感觉比较简单,总的概括之后感觉功能可以简略成if filter_words in ...
- Python 每日一练(3)
引言 今天的每日一练,学习了一下用Python生成四位的图像验证码,就是我们常常在登录时见到的那种(#`O′) 思路分析 正如常见的那种图像验证码,它是由数字和字母的随机组合产生的,所以我们首先的第一 ...
- Python 每日一练(2)
引言 我又双叒叕的来啦,新博客的第二篇文章,这次是继之前公众号上每日一练的第二个,这次是专题实对于文件的一些处理的练习 主要有以下几类: 1.实现英文文章字频统计 2.统一剪裁某一指定目录下的所有图片 ...
- Python每日一练(1):计算文件夹内各个文章中出现次数最多的单词
#coding:utf-8 import os,re path = 'test' files = os.listdir(path) def count_word(words): dic = {} ma ...
- Python 每日一练(7)
引言 今天的练习比较轻松,原本是有两题的,但是第一题那个大致看了一下,其实和之前的6个练习差不多,就是把xls中的文件数据读取出来后,进行一下处理,对于那题而言就是一个求和操作,所以就没练了,所以今天 ...
随机推荐
- 在Jetson TX2上安装caffe和PyCaffe
caffe是Nvidia TensorRT最支持的深度学习框架,因此在Jetson TX2上安装caffe很有必要.顺便说一句,下面的安装是支持python3的. 先决条件 在Jetson TX2上完 ...
- Fiddler手机端抓包环境设置与过滤(一)
一.PC端Fiddler设置 1.安装https 证书 打开Fiddler->Tool->Fiddler Options->HTTPS tab,勾选上并Capture HTTPS C ...
- JavaWeb----Servler
Servlet简介 Servlet就是sun公司开发动态web的一门技术 Sun在这些API中提供一个接口叫做:Servlet,如果你想开发一个Servlet程序,只需要完成两个小步骤: 编写一个类, ...
- C. Yet Another Counting Problem(循环节规律)
\(给出a,b,l,r,求在区间[l,r]内有多少x满足x%a%b!=x%b%a\) \(--------------------分割!!~----------------------------\) ...
- 设计模式(Java语言)- 建造者模式
前言 在日常的生活中,我们可以经常看到建造者模式的影子.比如,建造房子,那么房子就是一个产品,房子由门,窗,墙,地板等部门组成.然后包工头在建造房子的时候就根据设计好的图纸来建造,但是包工头并不是亲自 ...
- Collections集合工具类常用的方法
java.utils.Collections //是集合工具类,用来对集合进行操作.部分方法如下: public static <T> boolean addAll(Collection& ...
- Offset等一些类似属性的使用
1.offset系列 // offset 系列 var father = document.querySelector('.father'); var son = document.querySele ...
- 4-JVM 参数
JVM 参数 标准参数:不会随着jdk版本的变化而变化.比如:java -version.java -help 非标准参数:随着JDK版本的变化而变化. -X参数[用的较少]非标准参数,也就是在JDK ...
- TP5 order排序
order方法属于模型的连贯操作方法之一,用于对操作的结果排序. ->order('sort desc,id desc') 用法如下: Db::table('think_user')->w ...
- spring mvc --自定义converse
在MVC中我们可以很轻松的根据项目需求进行必要的信息转换,如设置默认的日期格式,自定义String类型的格式等等... 配置中我们需要自定义converseService: <bean id=& ...