day18、正则表达式和pygame 2019-01-16

一、复习

1.正则表达式

(1)匹配字符的符号

.
\w, \W -->
匹配数字,字母,下划线(和除了ASCLL码之外的所有字符),匹配非数字,字母,下划线(和除了ASCLL码之外的所有字符)
\s, \S --> 匹配字符串,匹配非字符串
\d, \D --> 匹配数字,匹配非数字
\b, \B, ^, $ --> 检测单词边界,非单词边界,字符串开头,字符串结尾
[], [^] --> 匹配在字符集中的任意字符,匹配不在字符集中的任意字符

(2)匹配次数的符号

* --> 匹配 0 或者多次
+ --> 匹配 1 或者多次
? --> 匹配 0或者 1 次
{M, N}, {M, }, {, N}, {N} --> 匹配 M 到 N 次,至少匹配 M 次,最多匹配 N 次,匹配 N 次

(3)分之

表达式1 | 表达式2 | 表达式3··· -->
匹配 表达式1 看对不对,不对就匹配 表达式2 ,再不对就匹配 表达式3 ,以此类推,直到分之里面所有的表达式都不匹配才返回 None

(4)分组

() --> 把括号里面的看成一个整体

\数字 -----重复前面第 数字 个分组匹配到的内容

二、贪婪

1.什么是贪婪:

在正则表达式中,控制不确定次数的符号后面,可以加 ? 来表示尽可能少的匹配
注意:尽可能少是在能够匹配到的前提下尽可能少;在非贪婪的时候,匹配是尽可能少的匹配
*? --> 非贪婪,能匹配尽可能少的匹配
+? --> 非贪婪,能匹配尽可能少的匹配
?? --> 非贪婪,能匹配尽可能少的匹配
{M, N}? --> 非贪婪,能匹配尽可能少的匹配
{M, }? --> 非贪婪,能匹配尽可能少的匹配
{, N}? --> 非贪婪,能匹配尽可能少的匹配
例如:

from re import search


def main():
    re_str1 = r'\d+'
    print(search(re_str1, 'asd123%^&'))
    re_str2 = r'\d+?'
    print(search(re_str2, 'asd123%^&'))


if __name__ == '__main__':
    main()

运行结果:

<_sre.SRE_Match object; span=(3, 6), match='123'>
<_sre.SRE_Match object; span=(3, 4), match='1'>

三、re 模块

1.comoile(正则表达式)

-----将正则表达式转换成正则对象,编译后,可以直接通过对象调用相关的对象方法

2.fullmatch(正则表达式, 字符串)

-----让正则表达式与字符串进行完全匹配,匹配成功就返回匹配对象
应用:检测字符串是否符合内容,例如:检测账号\密码\判断手机号\身份证号是否合法

1.span

-----匹配到的字符串在原字符串中的下标范围(结果是范围)

2.start() 和 end()

-----匹配到的字符串在原字符串中的开始下标和结束下标

3.group

-----获取匹配到的字符串(结果为字符串)

4.对象.string

-----获取原字符串

5.match(正则表达式, 字符串)

-----让字符串的开头和正则表达式进行匹配,匹配成功返回结果是匹配对象,否则返回Mone

6.search(正则表达式, 字符串)

-----在字符串中匹配出第一个符合正则表达式的子串,
匹配成功返回结果是匹配对象,否则返回Mone

7.split(正则表达式, 字符串)

-----将字符串按照满足正则要求的子串进行切割(返回值为列表)

8.sub(正则表达式, 字符串1, 字符串2)

-----将字 符串2 中匹配的子串替换成字 符串1 ,产生一个新的字符串

9.findall(正则表达式, 字符串)

-----在字符串中获取满足正则表达式的所有的子串(结果是列表)
注意:如果正则表达式中有分组,直接获取到的是分组中的内容;如果有多个分组,会返回一个列表,里面的元素是元组

10.finditer(正则表达式, 字符串)

-----在字符串中获取满足正则表达式的所有的子串(结果是迭代器,迭代器中的元素为)

11.re.I

-----匹配时忽略大小写;匹配的约束条件,放在函数的 flags 参数里面的
例如:

import re


def main():
    # 1.comoile(正则表达式) - ----将正则表达式转换成正则对象
    re_object = re.compile('\d{5}\D*')
    print(re_object)
    re_object.fullmatch('12456')

    # 2.fullmatch(正则表达式, 字符串) - ----让正则表达式与字符串进行完全匹配, 匹配成功就返回匹配对象
    result = re.fullmatch(r'(\d{5})([a-z]+)', '12345asdf')
    print(result)

    # 1.span - ----匹配到的字符串在原字符串中的下标范围(结果是范围)
    print(result.span())  # 获取整个正则表达式匹配到的内容的范围
    print(result.span(1))  # 获取正则表达式中第一个分组匹配到的内容的范围
    print(result.span(2))  # 获取正则表达式中第二个分组匹配到的内容的范围

    # 2.start 和 end - ----匹配到的字符串在原字符串中的开始下标和结束下标
    start, end = result.span()
    print(start, end)

    # 3.group - ----获取匹配到的字符串(结果为字符串)
    print(result.group())  # 获取整个正则表达式匹配到的字符串
    print(result.group(1))  # 获取第一个分组匹配到的字符串
    print(result.group(2))  # 获取第二个分组匹配到的字符串
    print(result.groups())  # 同时获取所有分组匹配到的字符串(返回结果为元组)

    # 4.对象.string         -----获取原字符串
    print(result.string)

    # 5.match(正则表达式, 字符串)         -----让字符串的开头和正则表达式进行匹配,匹配成功结果是匹配对象,否则返回Mone
    print(re.match(r'\D\d', 's123456asd&*('))

    # 6.search(正则表达式, 字符串)            -----在字符串中匹配出第一个符合正则表达式的子串,
    #                                                 匹配成功返回结果是匹配对象,否则返回Mone
    print(re.search(r'[\u4e00-\u9fa5]{3}', 'asd按时sdf阿萨德123456'))

    # 7.split(正则表达式, 字符串)         -----将字符串按照满足正则要求的子串进行切割(返回值为列表)
    # result = 'asdaszxcdasqwed123'.split('d')
    # print(result)
    print(re.split(r'\d+', 'asd123qwe^&*456gfh'))

    # 8.sub(正则表达式, 字符串1, 字符串2)            -----将字 符串2 中匹配的子串替换成字 符串1 ,产生一个新的字符串
    print(re.sub(r'\d+', '*', 'asd123qwe456%^&'))

    # 9.findall(正则表达式, 字符串)           -----在字符串中获取满足正则表达式的所有的子串(结果是列表)
    # 注意: 如果正则表达式中有分组, 直接获取到的是分组中的内容
    print(re.findall(r'\d+[a-z]', 'asd123qwe456%^&'))
    print(re.findall(r'(\d+)[a-z]', 'asd123qwe456%^&'))

    # 10.finditer(正则表达式, 字符串)         -----在字符串中获取满足正则表达式的所有的子串(结果是迭代器)
    result = re.finditer(r'\d+', 'asd123qwe456%^&')
    print(result)
    print(next(result).group())

    # 11.re.I - ----匹配时忽略大小写
    re.fullmatch(r'[a-z]{3}', 'Adc', re.I)


if __name__ == '__main__':
    main()

运行结果:

re.compile('\\d{5}\\D*')
<_sre.SRE_Match object; span=(0, 9), match='12345asdf'>
(0, 9)
(0, 5)
(5, 9)
0 9
12345asdf
12345
asdf
('12345', 'asdf')
12345asdf
<_sre.SRE_Match object; span=(0, 2), match='s1'>
<_sre.SRE_Match object; span=(8, 11), match='阿萨德'>
['asd', 'qwe^&*', 'gfh']
asd*qwe*%^&
['123q']
['123']
<callable_iterator object at 0x00000224B8208978>
123

四、游戏基本框架

例如:

import pygame


def base_game():
    # 1.初始化 pygame, 做准备工作
    pygame.init()

    # 2.创建游戏窗口
    '''
    set_mode(窗口大小)   <--->    set_mode((宽, 高))      -----会返回一个 surface 类型的对象
    窗口大小对应的是一个元组
    '''
    window1 = pygame.display.set_mode((600, 400))

    # 设置窗口标题
    pygame.display.set_caption('一块儿,找泥马!')

    # 设置窗口背景颜色
    '''
    fill(颜色)            -----
    颜色为一个元组,元组有三个 int 类型的元素,范围是 0 - 255 ,分别代表 R, G, B 
    计算机三原色:红(R),绿(G),蓝(B)
    红色:(255, 0, 0)
    绿色:(0, 255, 0)
    蓝色:(0, 0, 255)
    白色(255, 255, 255)
    黑色(0, 0, 0)
    '''
    window1.fill((200, 0, 200))

    # 想要对窗口内容进行的修改有效,就必须执行以下操作
    pygame.display.flip()

    # 3.让游戏保持运行状态(游戏循环)
    while True:
        # 4.不断检测运行过程中是否有事件产生
        #
        for event in pygame.event.get():
            # 只有当事件产生后,才会进入 for 循环
            if event.type == pygame.QUIT:
                # 退出
                # return 或者 exit()
                exit()


def main():
    base_game()


if __name__ == '__main__':
    main()

运行结果:

游戏基本框架

五、添加图片/显示图片

例如:

import pygame


def main():
    pygame.init()

    window1 = pygame.display.set_mode((800, 600))
    window1.fill((200, 200, 200))
    pygame.display.set_caption('显示图片')

    pygame.display.flip()

    # 添加固定显示内容
    '''
    显示图片
    1.加载图片
    image.load(图片地址)            -----返回图片对象
    '''
    image1 = pygame.image.load('./images/壁纸26.jpg')

    # 将图片添加(渲染)到窗口上
    # blit(渲染对象, 坐标)
    # 坐标:为一个元组;元素为 x坐标 和 y坐标
    window1.blit(image1, (0, 0))

    # 获取图片大小
    print(image1.get_size())

    # 获取窗口大小
    print(window1.get_size())

    # 2.图片的缩放和旋转(形变)
    # transform.scale(缩放对象, 目标大小(长与宽的比例))           -----返回缩放后的新对象
    # transform.rotozoom(缩放对象, 旋转角度, 缩放比例)
    new_image = pygame.transform.scale(image1, (500, 200))
    window1.blit(new_image, (200, 200))
    new_image = pygame.transform.rotozoom(image1, 45, 0.5)
    window1.blit(new_image, (70, 130))

    while True:
        for event in pygame.event.get():
            if event.type == pygame.QUIT:
                exit()


if __name__ == '__main__':
    main()

运行结果:


添加或显示图片

六、显示文字

例如:

import pygame


def base_game():
    # 1.初始化 pygame, 做准备工作
    pygame.init()

    # 2.创建游戏窗口
    '''
    set_mode(窗口大小)   <--->    set_mode((宽, 高))      -----会返回一个 surface 类型的对象
    窗口大小对应的是一个元组
    '''
    window1 = pygame.display.set_mode((600, 400))

    # 设置窗口标题
    pygame.display.set_caption('一块儿,找泥马!')

    # 设置窗口背景颜色
    '''
    fill(颜色)            -----
    颜色为一个元组,元组有三个 int 类型的元素,范围是 0 - 255 ,分别代表 R, G, B 
    计算机三原色:红(R),绿(G),蓝(B)
    红色:(255, 0, 0)
    绿色:(0, 255, 0)
    蓝色:(0, 0, 255)
    白色(255, 255, 255)
    黑色(0, 0, 0)
    '''
    window1.fill((200, 200, 200))

    # 想要对窗口内容进行的修改有效,就必须执行以下操作
    pygame.display.flip()

    '''
    1.创建字体对象
    a.系统字体
    font.SysFont(字体名, 字体大小)         -----返回一个字体对象(Surface)
    b.自定义字体
    font.Font(字体文件路径, 字体大小)
    '''
    # font1 = pygame.font.SysFont('Times', 20)
    font1 = pygame.font.Font('./files/font2.ttf', 40)

    '''
    2.根据字体创建文字对象
    render(文字, True, 文字颜色)         -----返回一个字体对象(Surface)
    '''
    text = font1.render('halo阿黄', True, (200, 0, 200))
    w, h = text.get_size()

    '''
    3.显示文字
    blit(渲染对象, 坐标)
    '''
    window1.blit(text, (600-w, 400-h))

    # 3.让游戏保持运行状态(游戏循环)
    while True:
        # 4.不断检测运行过程中是否有事件产生
        #
        for event in pygame.event.get():
            # 只有当事件产生后,才会进入 for 循环
            if event.type == pygame.QUIT:
                # 退出
                # return 或者 exit()
                exit()


def main():
    base_game()


if __name__ == '__main__':
    main()

运行结果:


显示文字.jpg

七、图形等

例如:

import pygame
import math


def base_game():
    # 1.初始化 pygame, 做准备工作
    pygame.init()

    # 2.创建游戏窗口
    '''
    set_mode(窗口大小)   <--->    set_mode((宽, 高))      -----会返回一个 surface 类型的对象
    窗口大小对应的是一个元组
    '''
    window1 = pygame.display.set_mode((600, 400))

    # 设置窗口标题
    pygame.display.set_caption('一块儿,找泥马!')

    # 设置窗口背景颜色
    '''
    fill(颜色)            -----
    颜色为一个元组,元组有三个 int 类型的元素,范围是 0 - 255 ,分别代表 R, G, B 
    计算机三原色:红(R),绿(G),蓝(B)
    红色:(255, 0, 0)
    绿色:(0, 255, 0)
    蓝色:(0, 0, 255)
    白色(255, 255, 255)
    黑色(0, 0, 0)
    '''
    window1.fill((200, 200, 200))

    # 画图形
    # 1.画线
    # line(画在的位置, 线的颜色, 起点, 终点, 线宽=1)
    pygame.draw.line(window1, (255, 255, 0), (20, 20), (200, 200), 10)

    # 2.画多条线
    # line(画在的位置, 线的颜色, 点列表, 线宽=1)
    list1 = [(200, 200), (250, 40), (300, 200), (165, 100), (335, 100)]
    pygame.draw.lines(window1, (255, 255, 255), True, list1, 5)

    # 3.画圆
    # circle(画在的地方, 线的颜色, 圆心, 半径, 线宽=0)
    pygame.draw.circle(window1, (255, 255, 255), (250, 250), 50, 0)
    pygame.draw.circle(window1, (255, 255, 255), (250, 250), 60, 1)

    # 4.画多边形
    pygame.draw.polygon(window1, (255, 0, 0), list1, 0)

    # 5.画弧线
    pygame.draw.arc(window1, (255, 255, 0), (100, 320, 150, 200), math.pi/2, math.pi/3, 3)

    # 6.画矩形
    pygame.draw.rect(window1, (255, 0, 0), (200, 300, 50, 50), 1)

    # 想要对窗口内容进行的修改有效,就必须执行以下操作
    pygame.display.flip()

    # 3.让游戏保持运行状态(游戏循环)
    point_list = []
    flag1 = False
    while True:
        # 4.不断检测运行过程中是否有事件产生
        for event in pygame.event.get():
            # 只有当事件产生后,才会进入 for 循环
            if event.type == pygame.QUIT:
                # 退出
                # return 或者 exit()
                exit()

            if event.type == pygame.MOUSEBUTTONUP:
                flag1 = False
                # pygame.draw.lines()
            elif event.type == pygame.MOUSEBUTTONDOWN:
                point_list = []
                flag1 = True
            elif event.type == pygame.MOUSEMOTION:
                point_list.append(event.pos)
                if len(point_list) < 2:
                    break
                if flag1:
                    pygame.draw.lines(window1, (250, 250, 0), False, point_list, 1)
                    pygame.display.flip()


def main():
    base_game()


if __name__ == '__main__':
    main()

运行结果:

图形等.jpg
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 211,948评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,371评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 157,490评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,521评论 1 284
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,627评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 49,842评论 1 290
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,997评论 3 408
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,741评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,203评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,534评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,673评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,339评论 4 330
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,955评论 3 313
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,770评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,000评论 1 266
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,394评论 2 360
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,562评论 2 349

推荐阅读更多精彩内容