2019-04(1)(Python学习)

9.1 迭代器

 

创建迭代器的3种方法:

方法一:

容器对象添加 __iter__() 和 __next__() 方法(Python 2.7 中是 next());__iter__() 返回迭代器对象本身 self,__next__() 则返回每次调用 next() 或迭代时的元素;

自定义一个迭代器:

1.    class Contain:  
2.        def __init__(self,start,end):  
3.            self.start = start          #self.start既是开始位置,也是记录位置的状态  
4.            self.end = end  
5.        def __iter__(self):  
6.            print('调用iter方法!')  
7.            return self     #/__iter()__返回自身self  
8.        def __next__(self):  
9.            if self.start < self.end:  
10.                i = self.start  
11.                self.start += 1  
12.                return i  
13.            else:  
14.                raise StopIteration  
15.    Con = Contain(0,5)  
16.    for i in Con:  
17.        print(i)                          

方法二:

使用内建函数iter()可以从可迭代对象中获得迭代器。示例:

1.    li = [2,5,3,7,9,10]  
2.    it = iter(li)  
3.    print(next(it), end=' ')    #2  
4.    print(next(it), end=' ')    #5以此类推  

方法三:

利用生成器(generator),生成器通过yield语句快速生成迭代器,省略了复杂的__iter()____next()__方式

参考原文:https://blog.csdn.net/qq_42068900/article/details/80369029

9.2 生成器

创建生成器:

1generator 第一种创建方式(推导式)

输入: 

1.    nums = (x for x in range(10))  
2.    print(nums)              #<generator object <genexpr> at 0x0000004590AB9938>  生成器类型  
3.    for i in nums:  
4.        print(i, end=' ')    #0 1 2 3 4 5 6 7 8 9 

输出:

runfile('C:/Users/lf/Desktop/Python/Python练习/迭代器和生成器.py', wdir='C:/Users/lf/Desktop/Python/Python练习')  

<generator object <genexpr> at 0x000002899B831360>  

0 1 2 3 4 5 6 7 8 9   

2:第二种创建方式(斐波那契数列):

输入:

1.    fibs = []  
2.    def Fib():  
3.        for i in range(100):  
4.            if i > 1:  
5.                fibs.append(fibs[i-2]+fibs[i-1])  
6.            else:  
7.                fibs.append(1)  
8.            yield fibs[i]     #print换成yield ,每次生成一个值  
9.    fibnaqi = Fib()  
10.    print(fibnaqi.__next__())   #1  
11.    print(next(fibnaqi))        #1  
12.    print(next(fibnaqi))        #2  
13.    print(next(fibnaqi))        #3  
14.    print(next(fibnaqi))        #5  
15.    print(next(fibnaqi))        #8  
16.    print(next(fibnaqi))        #13

输出:

runfile('C:/Users/lf/Desktop/Python/Python练习/迭代器和生成器.py', wdir='C:/Users/lf/Desktop/Python/Python练习') 

1  1  2  3  5  8  13 

9.3 打开文件

标准函数是:

open(filename,mode=’r’,buffering=-1,encoding=None, errors=None, newline=None, closefd=True, opener=None)

 

常见问题:

Python中遇到"UnicodeDecodeError: ‘gbk’ codec can’t decode bytes in position 2-3: illegal multibyte sequence"之类的编码或解码的错误时如何处理。

如何解决,参考原文:https://www.crifan.com/summary_python_unicodedecode_error_possible_reasons_and_solutions/

9.4 读取文件

1:readlines()

 

2:readline()

 

3:read()

 

4:tell()

 

5:truncate()

 

6:seek()

9.5 写入文件

1:write() 将字符串写入文件

 

2:writelines() 写入多行数据

 

9.6 关闭和刷新文件

 1:close() 关闭文件函数

2:flush() 刷新文件

12.1 图像的处理

1、下载和安装Pillow

方法一:

方法二:

 

2、加载图像文件

示例一:

示例二:

from tkinter import *
from PIL import Image, ImageTk
#创建主窗口
win = Tk()
win.title(string="加载图像文件")imgFile1 = Image.open(r'C:\Users\lf\Desktop\Python\01.bmp')
imgFile2 = Image.open(r'C:\Users\lf\Desktop\Python\02.jpg')
imgFile3 = Image.open(r'C:\Users\lf\Desktop\Python\03.tif')
imgFile4 = Image.open(r'C:\Users\lf\Desktop\Python\04.gif')img1 = ImageTk.PhotoImage(imgFile1)
img2 = ImageTk.PhotoImage(imgFile2)
img3 = ImageTk.PhotoImage(imgFile3)
img4 = ImageTk.PhotoImage(imgFile4)canvas = Canvas(win, width=850,height=500)
canvas.create_image(0, 0, image=img1, anchor=NW)
canvas.create_image(450, 0, image=img2, anchor=NW)
canvas.create_image(0, 250, image=img3, anchor=NW)
canvas.create_image(450, 250, image=img4, anchor=NW)
canvas.pack(fill = BOTH)#开始程序循环
win.mainloop()

3、复制与粘贴图像

image模块的copy()方法,来复制该图像,copy();

image模块的paste()方法,来粘贴该图像,paste(image, box);

image模块的crop()方法,剪切该图像中的一个矩形方块,crop(box)。

示例:

from tkinter import *
from PIL import Image, ImageTk
#创建主窗口
win = Tk()
win.title(string="复制与粘贴图像")
#打开图像文件
imgFile = Image.open(r'C:\Users\lf\Desktop\Python\test02.jpg')
#创建第一个图像实例变量
img1 = ImageTk.PhotoImage(imgFile)
#读取图像文件的宽和高
width, height = imgFile.size
#设置剪切下的区块范围
box1 = (0, 0, width, int(height/2))
#将图像的上半部分剪切下来
part = imgFile.crop(box1)
#将剪切下的部分旋转
part = part.transpose(Image.ROTATE_180)
#将剪切下,处理后的部分,粘贴
imgFile.paste(part, box1)
#创建第二个图像实例变量
img2 = ImageTk.PhotoImage(imgFile)
#创建Label控件,来显示图像
label1 = Label(win, width=400, height=400, image=img1, borderwidth=1)
label2 = Label(win, width=400, height=400, image=img2, borderwidth=1)
label1.pack(side= LEFT)
label2.pack(side= LEFT)
#开始循环程序
win.mainloop()

4、图像的几何转换

(1)改变图像的大小:使用resize()方法,语法格式为resize((width, height));

(2)旋转图像:使用rotate()方法,语法格式为rotate(angle);

(3)颠倒图像:使用transpose()方法,语法格式为transpose(method)。

示例:

from tkinter import *
from PIL import Image, ImageTk
#创建主窗口
win = Tk()
win.title(string="图像的几何转换")
#打开图像文件
imgFile1 = Image.open(r'C:\Users\lf\Desktop\Python\test1.jpg')
#创建第一个图像实例变量
img1 = ImageTk.PhotoImage(imgFile1)
#创建Label1控件,来显示原始图像
label1 = Label(win, width=300, height=400, image=img1)
label1.pack(side = LEFT)
#旋转图像成45°角
imgFile2 = imgFile1.rotate(45)
img2 = ImageTk.PhotoImage(imgFile2)
#创建Label2控件,来显示图像
label2 = Label(win, width=300, height=400, image=img2)
label2.pack(side = LEFT)
#旋转图像成90°角
imgFile3 = imgFile1.transpose(Image.ROTATE_90)
img3 = ImageTk.PhotoImage(imgFile3)
#创建Label3控件,来显示图像
label3 = Label(win, width=300, height=400, image=img3)
label3.pack(side = LEFT)
#改变图像为四分之一大小
width, height = imgFile1.size
imgFile4 = imgFile1.resize((int(width/2),int(height/2)))
img4 = ImageTk.PhotoImage(imgFile4)
#创建Label3控件,来显示图像
label4 = Label(win, width=300, height=400, image=img4)
label4.pack(side = LEFT)
#开始循环程序
win.mainloop()

13.3 操作MYSQL数据库

 Python中操作MySQL的模块是PyMySQL,在导入MySQL数据之前,需要安装PyMySQL模块。目前Python3.x仅支持PyMySQL,不支持MySQLdb。安装PyMySQL,如下:

 

1、连接数据库

代码:

import pymysql
#打开数据库连接
db = pymysql.connect('localhost','lifeng','123456','shopping')
#使用cursor()方法,创建一个游标对象cursor
cursor = db.cursor()
#使用execute()方法执行SQL查询
cursor.execute("SELECT VERSION()")
#使用fetchone()方法获取单条数据
data = cursor.fetchone()
#打印数据库版本号
print("Database version:%s" % data)
#关闭数据库
db.close()

2、在数据库创建表

代码:

import pymysql
#打开数据库连接
db = pymysql.connect('localhost','lifeng','123456','pymysql')
#使用cursor()方法,创建一个游标对象cursor
cursor = db.cursor()
#定义SQL语句
sql = """CREATE TABLE student4(id INT(10) NOT NULL UNIQUE,\name CHAR(20) NOT NULL, age INT, sex CHAR(1))"""
#使用execute()方法执行SQL查询
cursor.execute(sql)
#关闭数据库
db.close()

3、在数据库插入数据

代码:

import pymysql
import sys
#打开数据库连接
db = pymysql.connect('localhost','lifeng','123456','pymysql')
#使用cursor()方法,创建一个游标对象cursor
cursor = db.cursor()
#定义SQL语句
sql = "INSERT INTO student (id, name, age, sex) VALUES ('%d', '%s', '%d', '%s')" % (4 , '迪丽热巴', 25, 'F')
try:#执行插入数据语句
    cursor.execute(sql)#提交到数据库执行
    db.commit()
except:#如果发生错误,则回滚到插入操作之前info = sys.exc_info()exc_type = info[0]exc_value = info[1]exc_traceback = info[2]print (exc_type, ":", exc_value)db.rollback() #回滚函数,回到错误操作之前,防止错误数据被插入。
#关闭数据库
db.close()

插入后的结果:

4、查询数据库

代码:

import pymysql
#打开数据库连接
db = pymysql.connect('localhost','lifeng','123456','pymysql')
#使用cursor()方法,创建一个游标对象cursor
cursor = db.cursor()
#定义SQL语句
sql = "SELECT * FROM student WHERE age > '%d'" % (23)
try:#执行插入数据语句
    cursor.execute(sql)results = cursor.fetchall()for row in results:id = row[0]name = row[1]age = row[2]sex = row[3]#打印查询结果print ("id=%d, name=%s, age=%d, sex=%s " % (id, name, age, sex))
except:#如果发生错误,则回滚到插入操作之前print("错误:无法查询到数据!!!")
#关闭数据库
db.close()

查询结果:

5、修改数据库数据

代码:

import pymysql
#打开数据库连接
db = pymysql.connect('localhost','lifeng','123456','pymysql')
#使用cursor()方法,创建一个游标对象cursor
cursor = db.cursor()
#定义SQL语句
sql = "UPDATE student SET age=age -1"
try:#执行插入数据语句
    cursor.execute(sql)#提交到数据库执行
    db.commit()
except:db.rollback() #回滚函数,回到错误操作之前,防止错误数据被插入。
#关闭数据库
db.close()

修改结果:

6、删除数据库数据

代码:

import pymysql
import sys
#打开数据库连接
db = pymysql.connect('localhost','lifeng','123456','pymysql')
#使用cursor()方法,创建一个游标对象cursor
cursor = db.cursor()
#定义SQL语句
sql = "DELETE FROM student WHERE sex = '%s'" % ('F')
try:#执行插入数据语句
    cursor.execute(sql)#提交到数据库执行
    db.commit()
except:#如果发生错误,则回滚到插入操作之前info = sys.exc_info()exc_type = info[0]exc_value = info[1]exc_traceback = info[2]print (exc_type, ":", exc_value)db.rollback() #回滚函数,回到错误操作之前,防止错误数据被插入。
#关闭数据库
db.close()

删除后结果:

7、遇到的问题

期间遇到一个问题:<class 'pymysql.err.OperationalError'> : (1142, "DELETE command denied to user 'lifeng'@'localhost' for table 'student'");

是因为“lifeng”这个数据库没有DELETE权限,需要设置权限,参考:https://blog.csdn.net/u014183172/article/details/78509017

 ——————————————————————————————————————————————————————————————————

初步了解numpy、pandas等内容,以及数据处理部分内容。下周准备学习数据处理、数据分析两章内容,进行简单的数据分析。

转载于:https://www.cnblogs.com/lifengB511/p/10700989.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/350880.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

ubuntu 查看进程信息

查看进程信息 ps ps -aux 查看所有进程&#xff0c;每行一个程序 top 显示当前运行程序 kill 98 &#xff08;98为PID号&#xff0c;&#xff09; kill -9 98 &#xff08;强制杀死98&#xff09;

浏览器崩溃_字节跳动程序员28岁身价上亿,财务自由宣布退休;微软最新系统再迎“喜报”:更多用户的浏览器开始崩溃...

新闻1&#xff1a;字节跳动程序员28岁身价上亿&#xff0c;财务自由宣布退休最近字节跳动前员工郭宇火了。原因是他在今年二月份发了一条微博。大概是说他在28岁的年纪实现了财务自由&#xff0c;然后选择了退休。郭宇本来是字节跳动的一名程序员&#xff0c;但现在已经离职去往…

Python图像处理库PIL中图像格式转换(一)

在数字图像处理中&#xff0c;针对不同的图像格式有其特定的处理算法。所以&#xff0c;在做图像处理之前&#xff0c;我们需要考虑清楚自己要基于哪种格式的图像进行算法设计及其实现。本文基于这个需求&#xff0c;使用Python中的图像处理库PIL来实现不同图像格式的转换。 对…

spring 构造函数注入_Spring构造函数注入和参数名称

spring 构造函数注入在运行时&#xff0c;除非在启用了调试选项的情况下编译类&#xff0c;否则Java类不会保留构造函数或方法参数的名称。 这对于Spring构造函数注入有一些有趣的含义。 考虑以下简单的类 package dbg; public class Person {private final String first;pr…

C#基础加强(8)之委托和事件

委托 简介 委托是一种可以声明出指向方法的变量的数据类型。 声明委托的方式 格式&#xff1a; delegate <返回值类型> 委托类型名(参数) &#xff0c;例如&#xff1a; delegate void MyDel(string str) 。 // 注意&#xff1a;这里除了前面的 delegate 关键字&#xff…

模板类的析构函数如何写_顶尖文案如何写?这6大模板、29个方法,奥美大咖都在用!|优惠最后1天...

敲黑板划重点&#xff1a;《顶尖文案训练营》第5期将于2月20日(正月十六)开班&#xff0c;现在报名享受春节特惠8折优惠&#xff0c;今天是优惠最后1天&#xff01;先到先得&#xff0c;速速报名抢位&#xff5e;马上就是2.14情人节了&#xff0c;馒火火在这里提前祝大家情人节…

ubuntu 查看日历,日期

cal 查看当前月日历 cal -y 2008 查看2008年日历 cal -y 2008 > 123.txt 打印到123.txt date 当前日期具体时间 date “%y年%m月%d日”

有效的Java –所有对象通用的方法

所有对象共有的方法&#xff08;第3章&#xff09; 这是Joshua Blochs的《 有效的Java》第3章的简短摘要。我仅包括与自己相关的项目。 一般 等值合约将等价关系描述为&#xff1a; x.equals(null) false 自反 – x.equals(x) true 对称 –如果x.equals(y) true则y.equa…

几种页面置换算法

地址映射过程中&#xff0c;若在页面中发现所要访问的页面不再内存中&#xff0c;则产生缺页中断。当发生缺页中断时操作系统必须在内存选择一个页面将其移出内存&#xff0c;以便为即将调入的页面让出空间。而用来选择淘汰哪一页的规则叫做页面置换算法。常见的置换算法有&…

win7摄像头怎么开_win7网络连接不可用怎么办

win7网络连接不可用怎么办&#xff1f;网络出现故障最常见的就是网络明明连接上&#xff0c;但是依然提示网络连接不可用&#xff0c;小白系统遇到最常见的就是使用win7系统的用户反馈的&#xff0c;下面让小白系统教你解决win7网络连接不可用的问题吧。首先我们判断网络状态是…

cmake--安装

一&#xff0c; 目录结构 ├── cmake-examples.conf├── CMakeLists.txt├── include│ └── installing│ └── Hello.h└── src ├── Hello.cpp └── main.cpp * link:CMakeLists.txt[] - Contains the CMake commands yo…

ubuntu 关机重启

关机&#xff0c;重启 reboot &#xff08;重启&#xff09; shutdown -h now &#xff08;立刻关机&#xff09; shutdown -h 10 &#xff08;10min后立刻关机&#xff09; shutdown -h 20:05 &#xff08;今天20:05立刻关机&#xff09;

excel合并两列内容_excel新手问题:怎么把两列数据合并到一起?用这个公式

今天看见有新手在问&#xff1a;怎么把两列数据合并到一起&#xff1f;其实&#xff0c;这种情况在工作中会经常遇到&#xff0c;但很多人可能还在用复制粘贴的方法。只要掌握最简单的一个函数公式&#xff0c;就可以实现快速两列合并。第一步&#xff1a;掌握“&”运算符使…

Pycharm Anaconda 安装dlib

由于采用python3.7安装会出现各种问题&#xff0c;两种解决方法。 1&#xff09;安装Cmake boost等&#xff08;不推荐&#xff0c;麻烦且不容易成功&#xff09;。 2&#xff09;安装Anaconda&#xff0c;创建一个python3.6的环境。 这里使用第二种。 一、安装Anaconda 。 方法…

java 使用jasper_使用Jasper Reports以Java创建报告

java 使用jasper上周&#xff0c;我试图使用Jasper创建报告。 在这篇文章中&#xff0c;我将记录一些资源和链接&#xff0c;以便对任何寻求类似信息的人都有用。 我将介绍Jasper报告&#xff0c;示例和Dynamic Jasper的生命周期。 Jasper Reports是世界上最受欢迎的开源报告…

计算机科学基础知识(四): 动态库和位置无关代码

一、前言 本文主要描述了动态库以及和动态库有紧密联系的位置无关代码的相关资讯。首先介绍了动态库和位置无关代码的源由&#xff0c;了解这些背景知识有助于理解和学习动态库。随后&#xff0c;我们通过加-fPIC和不加这个编译选项分别编译出两个relocatable object file&…

安装后添加没有class library_《没有秘密的你》:戚薇曝光手机号,粉丝急忙添加后却甜哭了?...

现在大家对于戚薇都是非常熟悉的吧&#xff0c;现在她可以说是娱乐圈内非常受关注的一个明星了&#xff0c;因为自己的颜值和耿直的性格也是直接圈粉无数&#xff0c;当时自己没有很多名气的时候&#xff0c;更是因为自己的女儿增添了很多的人气。想必在今年夏天的时候&#xf…

ubuntu 硬盘使用情况

df &#xff08;硬盘使用情况&#xff09; df -h du &#xff08;当前文件夹多大&#xff09; du -h

执行器的Spring启动和安全性事件

Spring Boot Actuator提供了审核功能&#xff0c;用于在启用Spring Security的Spring Boot应用程序中发布和侦听与安全相关的事件。 默认事件是身份验证成功&#xff0c;身份验证失败和访问被拒绝&#xff0c;但是可以使用自定义事件进行扩展。 确保在项目中启用了Spring Boot…