这两天在做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)的更多相关文章

  1. python每日一练:0007题

    第 0007 题: 有个目录,里面是你自己写过的程序,统计一下你写过多少行代码.包括空行和注释,但是要分别列出来. # -*- coding:utf-8 -*- import os def count ...

  2. [python每日一练]--0012:敏感词过滤 type2

    题目链接:https://github.com/Show-Me-the-Code/show-me-the-code代码github链接:https://github.com/wjsaya/python ...

  3. Python 每日一练 | Flask 实现半成品留言板

    留言板Flask实现 引言 看了几天网上的代码,终于写出来一个半成品的Flask的留言板项目,为什么说是半成品呢?因为没能实现留言板那种及时评论刷新的效果,可能还是在重定向上有问题 或者渲染写的存在问 ...

  4. Python 每日一练(5)

    引言 Python每日一练又开始啦,今天的专题和Excel有关,主要是实现将txt文本中数据写入到Excel中,说来也巧,今天刚好学校要更新各团支部的人员信息,就借此直接把事情做了 主要对于三种数据类 ...

  5. Python 每日一练(4)

    引言 今天继续是python每日一练的几个专题,主要涵盖简单的敏感词识别以及图片爬虫 敏感词识别 这个敏感词的识别写的感觉比较简单,总的概括之后感觉功能可以简略成if filter_words in ...

  6. Python 每日一练(3)

    引言 今天的每日一练,学习了一下用Python生成四位的图像验证码,就是我们常常在登录时见到的那种(#`O′) 思路分析 正如常见的那种图像验证码,它是由数字和字母的随机组合产生的,所以我们首先的第一 ...

  7. Python 每日一练(2)

    引言 我又双叒叕的来啦,新博客的第二篇文章,这次是继之前公众号上每日一练的第二个,这次是专题实对于文件的一些处理的练习 主要有以下几类: 1.实现英文文章字频统计 2.统一剪裁某一指定目录下的所有图片 ...

  8. Python每日一练(1):计算文件夹内各个文章中出现次数最多的单词

    #coding:utf-8 import os,re path = 'test' files = os.listdir(path) def count_word(words): dic = {} ma ...

  9. Python 每日一练(7)

    引言 今天的练习比较轻松,原本是有两题的,但是第一题那个大致看了一下,其实和之前的6个练习差不多,就是把xls中的文件数据读取出来后,进行一下处理,对于那题而言就是一个求和操作,所以就没练了,所以今天 ...

随机推荐

  1. 顺序表的C语言实现

    在现实应用中,有两种实现线性表数据元素存储功能的方法,分别是顺序存储结构和链式存储结构.顺序表操作是最简单的操作线性表的方法.下面的代码实现了顺序表的几种简单的操作.代码如下 //start from ...

  2. SSTI(服务器模板注入)学习

    SSTI(服务器模板注入)学习 0x01 SSTI概念 SSTI看到ss两个字母就会想到服务器,常见的还有SSRF(服务器端请求伪造).SSTI就是服务器端模板注入(Server-Side Templ ...

  3. jQuery如何使用键盘事件,按住空格键完成进度条效果,并终止键盘事件

    jQuery使用键盘事件 keyup:键盘抬起时 keydown:键盘按下时 keypress:键盘按住时 运行下列代码,可以看效果 $(document).keyup(function () { c ...

  4. B - Lawrence HDU - 2829 斜率dp dp转移方程不好写

    B - Lawrence HDU - 2829 这个题目我觉得很难,难在这个dp方程不会写. 看了网上的题解,看了很久才理解这个dp转移方程 dp[i][j] 表示前面1~j 位并且以 j 结尾分成了 ...

  5. Spring官网阅读(三)自动注入

    上篇文章我们已经学习了1.4小结中关于依赖注入跟方法注入的内容.这篇文章我们继续学习这结中的其他内容,顺便解决下我们上篇文章留下来的一个问题-----注入模型. 文章目录 前言: 自动注入: 自动注入 ...

  6. 实用,小物体检测的有监督特征级超分辨方法 | ICCV 2019

    论文提出新的特征级超分辨方法用于提升检测网络的小物体检测性能,该方法适用于带ROI池化的目标检测算法.在VOC和COCO上的小物体检测最大有5~6%mAP提升,在Tsinghua-Tencent 10 ...

  7. 【HBase】通过Bulkload批量加载数据到Hbase表中

    目录 需求 步骤 一.开发MapReduce 二.打成Jar包放到linux执行 三.有两种办法将HFile文件加载到HBase表中 开发代码 Hadoop命令运行 需求 将hdfs上面的这个路径 / ...

  8. Linux内核驱动学习(十)Input子系统详解

    文章目录 前言 框架 如何实现`input device` 设备驱动? 头文件 注册input_dev设备 上报按键值 dev->open()和dev->close() 其他事件类型,处理 ...

  9. 配置类为什么要添加@Configuration注解呢?

    配置类为什么要添加@Configuration注解呢? 本系列文章: 读源码,我们可以从第一行读起 你知道Spring是怎么解析配置类的吗? 推荐阅读: Spring官网阅读 | 总结篇 Spring ...

  10. 关于C语言的位运算符

    早期cpu架构在运行位运算时 略微领先 + - 运算 大幅领先 * / % 运算 '&' 运算符 总结 两个二进制中对应的位置都为 1 结果的对应二进制为 1 '&'运算符可以用到奇偶 ...