用python自带的tkinter做游戏(一)—— 贪吃蛇 篇

用python自带的tkinter做游戏(一)—— 贪吃蛇 篇


  本人新手,刚自学python满半年,现分享下心得,希望各位老手能指点一二,也希望和我一样的新手能共勉,谢谢~
  大家都知道用python做游戏用的比较多的是pygame。其实做游戏最重要的是思路,用什么库并不重要,特别是些小游戏,用自带的tkinter完全能胜任。虽然tkinter存在着各种的不便,但毕竟是自带的,用起来也简单,非常适合新手入门。
  
  废话少说,开始正题。选贪吃蛇做入门练手游戏最适合不过了,没玩过的也应该见过吧?先随我一起看看游戏的设计思路~
  贪吃蛇游戏画面很简单,若干个方格组成一个矩阵,颜色最低三色即可,空地,食物和蛇身。我这里用了五种颜色,增加了四周的墙和蛇头(蛇头和蛇身颜色分开,更直观些)。
  其实贪吃蛇这个游戏控制的就是蛇头的走向,蛇身其实就是蛇头的运动轨迹,只要记录下蛇头的每一步坐标,然后根据所需要的长度,就可以拼凑出蛇身来。有个这个思路,这个游戏制作起来就简单了。
  
  
好了,开始了, 先加载需要的库。

import tkinter as tk
from tkinter.messagebox import showinfo
import random

showinfo是个弹窗,暂停游戏时用。
random都知道,生成随机数。

然后设置下游戏参数。

class Snake():""" 贪吃蛇游戏  """def __init__(self):""" 游戏参数设置 """global body_len, FPSself.len        = 3                   # 蛇身初始长度(最小设定值为1,不包括蛇头)body_len        = self.len            # 蛇身当前长度FPS             = 120                 # 蛇的移动速度(单位毫秒)self.row_cells  = 22                  # 一行多少个单元格(含边框)self.col_cells  = 22                  # 一共多少行单元格(含边框)self.canvas_bg  = 'white'             # 游戏背景色self.cell_size  = 25                  # 方格单元格大小self.cell_gap   = 1                   # 方格间距self.frame_x    = 15                  # 左右边距self.frame_y    = 15                  # 上下边距self.win_w_plus = 220                 # 窗口右边额外多出的宽度self.color_dict = {0:  '#d7d7d7',     # 0表示空白1:   'yellow',     # 1代表蛇头2:  '#009700',     # 2代表蛇身3:      'red',     # 3代表食物4:  '#808080'}     # 4代表墙

body_len不要设置为0,不然连蛇头都没有了。
  
之前提到的五种颜色,放置在color_dict这个字典中,方便调用。
然后游戏窗口设置成居中。

    def window_center(self,window,w_size,h_size):""" 窗口居中 """screenWidth  =  window.winfo_screenwidth()  # 获取显示区域的宽度screenHeight = window.winfo_screenheight()  # 获取显示区域的高度left =  (screenWidth - w_size) // 2top  = (screenHeight - h_size) // 2window.geometry("%dx%d+%d+%d" % (w_size, h_size, left, top))

没学过tkinter的同学也可以简单了解一下tk的语法,之后就显示窗体了。

    def run_game(self):""" 开启游戏 """global windowwindow = tk.Tk()window.focus_force() # 主窗口焦点window.title('Snake')win_w_size = self.row_cells * self.cell_size + self.frame_x*2 + self.win_w_plus win_h_size = self.col_cells * self.cell_size + self.frame_y*2self.window_center(window,win_w_size,win_h_size)txt_lable = tk.Label(window, text="方向键移动,或者"+"\n字母键WSAD移动"+"\n(大小写均可)"+"\n"+"\n空格键暂停"+"\n作者:Juni Zhu"+"\n微信:znix1116",font=('Yahei', 15),anchor="ne", justify="left")txt_lable.place(x = self.cell_size * self.col_cells + self.cell_size*2, y = self.cell_size*6)self.create_canvas()self.game_start()

窗体架构完了,开始游戏内容了。先创建个游戏地图,既然是若干个方格所组成的矩阵,那每个方格就对应一个坐标吧。

    def create_map(self):""" 创建地图列表 """global game_mapgame_map = [] for i in range(0,self.col_cells):game_map.append([])for i in range(0,self.col_cells):for j in range(0,self.row_cells):game_map[i].append(j)   game_map[i][j] = 0  # 生成一个全是0的空数列

有了这张game_map就可以开始作画了,先画上四周的边框。

    def create_wall(self):""" 绘制边框 """for i in range(0,self.row_cells-1):game_map[0][i] = 4game_map[self.col_cells-1][i] = 4for i in range(0,self.col_cells-1):game_map[i][0] = 4game_map[i][self.row_cells-1] = 4game_map[-1][-1] = 4

边框有了,接着把蛇头画出来。

    def create_snake(self):""" 创建蛇头和蛇身 """global snake_bodysnake_body = [[self.col_cells // 2 , self.row_cells // 2]] # 蛇头出生地在地图的中央game_map[snake_body[0][0]][snake_body[0][1]] = 1  # 蛇头上色,颜色为定义的1

snake_body是个列表,初始只有蛇头的坐标,之后的蛇身因为蛇头还没开始走动,所以还没有生成。

蛇头有了,接下来就是食物了,这回随机数派上用处了。

    def create_food(self):""" 创建食物 """global food_xyfood_xy = [0,0]food_xy[1] = random.randint(1, self.row_cells-2)food_xy[0] = random.randint(1, self.col_cells-2)while game_map[food_xy[0]][food_xy[1]] != 0:food_xy[0] = random.randint(1,self.row_cells-2)food_xy[1] = random.randint(1,self.col_cells-2)game_map[food_xy[0]][food_xy[1]] = 3

食物必须得出现在空地上,不然嵌在墙里也就算了,直接在蛇身上冒出来总不合适吧。。。

现在,边框,蛇头和食物都定义好了,我们现在加载看看效果。

    def create_canvas(self):""" 创建画布 """global canvascanvas_h = self.cell_size * self.col_cells + self.frame_y*2canvas_w = self.cell_size * self.row_cells + self.frame_x*2canvas = tk.Canvas(window,  bg = self.canvas_bg, height = canvas_h,width = canvas_w,highlightthickness = 0)canvas.place(x=0,y=0)def create_cells(self):""" 创建单元格 """for y in range(0,self.col_cells):for x in range(0,self.row_cells):a = self.frame_x + self.cell_size*xb = self.frame_y + self.cell_size*yc = self.frame_x + self.cell_size*(x+1)d = self.frame_y + self.cell_size*(y+1)e = self.canvas_bgf = self.cell_gapg = self.color_dict[game_map[y][x]]canvas.itemconfig(canvas.create_rectangle(a,b,c,d, outline=e, width=f, fill=g),fill=g)

用canvas创建方格,颜色填充根据颜色字典来。
如果现在把以上这些函数连起来运行的话,就可以看到画面中央有个黄色的蛇头静静的望着红色的食物一动不动。那怎么让蛇动起来呢?
蛇头一旦动起来,蛇身就会根据蛇头的运行轨迹而出现。所以在蛇运动起来之前,我们先要想办法知道蛇头的每一步坐标。

在这里插入图片描述

    def snake_xy(self):""" 获取蛇头坐标 """global head_x, head_yxy = []for i in range(0,self.col_cells):try: # 查找数值为1的坐标,没有就返回0。为防止在0列,先加上1,最后再减去。x = game_map[i].index(1) + 1 except:x = 0xy.append(x)head_x = max(xy)head_y = xy.index(head_x)head_x = head_x - 1 # 之前加1,现在减回

这样就得到了蛇头的XY轴的坐标,那就让它动起来!

    def move_snake(self,event):""" 蛇体移动 """def move_key(a,b,c,d):  # 记录按键的方向,1上2下3左4右direction = event.keysymif   head_x != snake_body[-1][1]:if(direction == a):dd[0] = 1if(direction == b):dd[0] = 2else:if(direction == c):dd[0] = 3if(direction == d):dd[0] = 4if   head_y != snake_body[-1][0]:if(direction == c):dd[0] = 3if(direction == d):dd[0] = 4else:if(direction == a):dd[0] = 1if(direction == b):dd[0] = 2def pause_key(key):""" 暂停键 """global loopdirection = event.keysymif(direction == key):loop = 0showinfo('暂停','按确定键继续')loop = 1window.after(FPS, self.game_loop)move_key('w','s','a','d')move_key('W','S','A','D')move_key('Up','Down','Left','Right')pause_key('space')

四个方向键只是记录方位,修改dd[0]的值,1~4分别为上下左右。顺便把暂停键空格也定义上,一按空格键,loop值就等于0,停止游戏界面刷新。

之前说过,蛇身就是蛇头的运动轨迹,既然蛇头动起来了,蛇身的数据也就得到了。

    def snake_record(self):""" 蛇身 """ # 记录蛇头运行轨迹,生成蛇身global body_len,snake_bodytemp = []temp.append(head_y)temp.append(head_x)snake_body.append(temp) if snake_body[-1] == snake_body[-2]: del snake_body[-1]if [head_y,head_x] == food_xy: # 碰到食物身体加长,并再随机生成一个食物body_len = body_len + 1self.create_food()elif len(snake_body) > body_len:  # 限制蛇身长度,不超过设定值game_map[snake_body[0][0]][snake_body[0][1]] = 0del snake_body[0]

这样所有的素材都齐全了,大功快要告成了!

    def game_over(self):def over():global body_lenshowinfo('Game Over','再来一局')body_len = self.lenself.game_start()if [head_y,head_x] in snake_body[0:-2]:over()if head_x == self.row_cells - 1 or head_x == 0:over()if head_y == self.col_cells - 1 or head_y == 0:over()def auto_move(self):""" 自动前进 """def move(d,x,y):if dd[0] == d:  # 根据方向值来决定走向game_map[head_y + x][head_x + y] = 1game_map[head_y + 0][head_x + 0] = 2move( 1, -1,  0 )move( 2,  1,  0 )move( 3,  0, -1 )move( 4,  0,  1 )

根据游戏设定,蛇头撞墙或者撞到自身了就Game Over。位置的移动根据蛇头的坐标X轴或Y轴加一或减一就行。蛇头前方的格子变成蛇头(1),然后原本蛇头的位置变为蛇身(2)。

现在让窗体自动刷新起来,这样蛇头才会自动前进。
并把所有的函数串起来。

    def game_loop(self):""" 游戏循环刷新 """global loop_idself.snake_record()self.auto_move()self.snake_xy()canvas.delete('all') # 清除canvasself.create_cells()self.game_over()if loop == 1:loop_id  = window.after(FPS, self.game_loop)def game_start(self):"""  """global window, backup_map, dd, looploop = 1 # 暂停标记,1为开启,0为暂停dd = [0] # 记录按键方向self.create_map()self.create_wall()self.create_snake()self.create_food()window.bind('<Key>', self.move_snake)self.snake_xy()self.game_loop()def close_w():global looploop = 0window.after_cancel(loop_id)window.destroy()window.protocol('WM_DELETE_WINDOW', close_w)window.mainloop()

loop值为1时,window.after起作用,让游戏界面根据FPS值不断刷新。

至此,这个贪吃蛇的游戏算是全部完成了,该有的功能都有,就缺个计分功能。
这个难度也不大,我就懒得添加了。

在这里插入图片描述

下期预告:
用python自带的tkinter做游戏(二)—— 俄罗斯方块 篇
(本人微信:znix1116,欢迎来交流)

最后附上完整代码:

2022.03.25 更新下代码,修复些小BUG(退出游戏后再次运行游戏会有提示报错)。

2022.05.31 修复一个BUG(游戏失败后,再次游戏后蛇身没有恢复成初始长度)。

2022.06.03 修复一处小BUG(游戏失败后再次游戏,退出游戏的时候会提示报错)。

2023.04.03 无聊小更新一下,把global的定义全部取消了。

# -*- coding: utf-8 -*-
"""
Created on Sat Mar 27 17:45:21 2021@author: Juni Zhu
"""import tkinter as tk
from tkinter.messagebox import showinfo
import randomclass Snake():""" 贪吃蛇游戏  """def __init__(self):""" 游戏参数设置 """self.window     = None                # 实例化的窗体self.canvas     = None                # 实例化的画布self.loop       = 0                   # 暂停标记,1为开启,0为暂停self.loop_id    = None                # 实例化loop,用来取消循环self.game_map   = []                  # 整个游戏的地图self.snake_body = []                  # 蛇身的坐标集self.food_xy    = []                  # 食物的坐标self.head_x     = 0                   # 蛇头的X坐标self.head_y     = 0                   # 蛇头的Y坐标self.dd         = [0]                 # 记录按键方向self.len        = 3                   # 蛇身初始长度(最小设定值为1,不包括蛇头)self.body_len   = self.len            # 蛇身当前长度self.FPS        = 120                 # 蛇的移动速度(单位毫秒)self.row_cells  = 22                  # 一行多少个单元格(含边框)self.col_cells  = 22                  # 一共多少行单元格(含边框)self.canvas_bg  = 'white'             # 游戏背景色self.cell_size  = 25                  # 方格单元格大小self.cell_gap   = 1                   # 方格间距self.frame_x    = 15                  # 左右边距self.frame_y    = 15                  # 上下边距self.win_w_plus = 220                 # 窗口右边额外多出的宽度self.color_dict = {0:  '#d7d7d7',     # 0表示空白1:   'yellow',     # 1代表蛇头2:  '#009700',     # 2代表蛇身3:      'red',     # 3代表食物4:  '#808080'}     # 4代表墙self.run_game()def window_center(self,window,w_size,h_size):""" 窗口居中 """screenWidth  =  window.winfo_screenwidth()  # 获取显示区域的宽度screenHeight = window.winfo_screenheight()  # 获取显示区域的高度left =  (screenWidth - w_size) // 2top  = (screenHeight - h_size) // 2window.geometry("%dx%d+%d+%d" % (w_size, h_size, left, top))def create_map(self):""" 创建地图列表 """self.game_map = [] for i in range(0,self.col_cells):self.game_map.append([])for i in range(0,self.col_cells):for j in range(0,self.row_cells):self.game_map[i].append(j)   self.game_map[i][j] = 0  # 生成一个全是0的空数列def create_wall(self):""" 绘制边框 """for i in range(0,self.row_cells-1):self.game_map[0][i] = 4self.game_map[self.col_cells-1][i] = 4for i in range(0,self.col_cells-1):self.game_map[i][0] = 4self.game_map[i][self.row_cells-1] = 4self.game_map[-1][-1] = 4def create_canvas(self):""" 创建画布 """canvas_h = self.cell_size * self.col_cells + self.frame_y*2canvas_w = self.cell_size * self.row_cells + self.frame_x*2self.canvas = tk.Canvas(self.window,  bg = self.canvas_bg, height = canvas_h,width = canvas_w,highlightthickness = 0)self.canvas.place(x=0,y=0)def create_cells(self):""" 创建单元格 """for y in range(0,self.col_cells):for x in range(0,self.row_cells):a = self.frame_x + self.cell_size*xb = self.frame_y + self.cell_size*yc = self.frame_x + self.cell_size*(x+1)d = self.frame_y + self.cell_size*(y+1)e = self.canvas_bgf = self.cell_gapg = self.color_dict[self.game_map[y][x]]self.canvas.itemconfig(self.canvas.create_rectangle(a,b,c,d, outline=e, width=f, fill=g),fill=g)def create_snake(self):""" 创建蛇头和蛇身 """self.snake_body = [[self.col_cells // 2 , self.row_cells // 2]] # 蛇头出生地在地图的中央self.game_map[self.snake_body[0][0]][self.snake_body[0][1]] = 1  # 蛇头上色,颜色为定义的1def create_food(self):""" 创建食物 """self.food_xy = [0,0]self.food_xy[1] = random.randint(1, self.row_cells-2)self.food_xy[0] = random.randint(1, self.col_cells-2)while self.game_map[self.food_xy[0]][self.food_xy[1]] != 0:self.food_xy[0] = random.randint(1,self.row_cells-2)self.food_xy[1] = random.randint(1,self.col_cells-2)self.game_map[self.food_xy[0]][self.food_xy[1]] = 3def snake_xy(self):""" 获取蛇头坐标 """xy = []for i in range(0,self.col_cells):try: # 查找数值为1的坐标,没有就返回0。为防止在0列,先加上1,最后再减去。x = self.game_map[i].index(1) + 1 except:x = 0xy.append(x)self.head_x = max(xy)self.head_y = xy.index(self.head_x)self.head_x = self.head_x - 1 # 之前加1,现在减回def move_snake(self,event):""" 蛇体移动 """def move_key(a,b,c,d):  # 记录按键的方向,1上2下3左4右direction = event.keysymif   self.head_x != self.snake_body[-1][1]:if(direction == a):self.dd[0] = 1if(direction == b):self.dd[0] = 2else:if(direction == c):self.dd[0] = 3if(direction == d):self.dd[0] = 4if   self.head_y != self.snake_body[-1][0]:if(direction == c):self.dd[0] = 3if(direction == d):self.dd[0] = 4else:if(direction == a):self.dd[0] = 1if(direction == b):self.dd[0] = 2def pause_key(key):""" 暂停键 """direction = event.keysymif(direction == key):self.loop = 0showinfo('暂停','按确定键继续')self.loop = 1self.window.after(self.FPS, self.game_loop)move_key('w','s','a','d')move_key('W','S','A','D')move_key('Up','Down','Left','Right')pause_key('space')def game_over(self):def over():showinfo('Game Over','再来一局')self.body_len = self.lenself.game_start()if [self.head_y,self.head_x] in self.snake_body[0:-2]:over()if self.head_x == self.row_cells - 1 or self.head_x == 0:over()if self.head_y == self.col_cells - 1 or self.head_y == 0:over()def snake_record(self):""" 蛇身 """ # 记录蛇头运行轨迹,生成蛇身temp = []temp.append(self.head_y)temp.append(self.head_x)self.snake_body.append(temp) if self.snake_body[-1] == self.snake_body[-2]: del self.snake_body[-1]if [self.head_y,self.head_x] == self.food_xy: # 碰到食物身体加长,并再随机生成一个食物self.body_len += 1self.create_food()elif len(self.snake_body) > self.body_len:  # 限制蛇身长度,不超过设定值self.game_map[self.snake_body[0][0]][self.snake_body[0][1]] = 0del self.snake_body[0]def auto_move(self):""" 自动前进 """def move(d,x,y):if self.dd[0] == d:  # 根据方向值来决定走向self.game_map[self.head_y + x][self.head_x + y] = 1self.game_map[self.head_y + 0][self.head_x + 0] = 2move( 1, -1,  0 )move( 2,  1,  0 )move( 3,  0, -1 )move( 4,  0,  1 )def game_loop(self):""" 游戏循环刷新 """self.snake_record()self.auto_move()self.snake_xy()self.canvas.delete('all') # 清除canvasself.create_cells()self.game_over()if self.loop == 1:self.loop_id  = self.window.after(self.FPS, self.game_loop)def game_start(self):"""  """self.loop = 1 # 暂停标记,1为开启,0为暂停self.dd = [0] # 记录按键方向self.create_map()self.create_wall()self.create_snake()self.create_food()self.window.bind('<Key>', self.move_snake)self.snake_xy()self.game_loop()def close_w():self.loop = 0self.window.after_cancel(self.loop_id)self.window.destroy()self.window.protocol('WM_DELETE_WINDOW', close_w)self.window.mainloop()def run_game(self):""" 开启游戏 """self.window = tk.Tk()self.window.focus_force() # 主窗口焦点self.window.title('Snake')win_w_size = self.row_cells * self.cell_size + self.frame_x*2 + self.win_w_plus win_h_size = self.col_cells * self.cell_size + self.frame_y*2self.window_center(self.window,win_w_size,win_h_size)txt_lable = tk.Label(self.window, text="方向键移动,或者"+"\n字母键WSAD移动"+"\n(大小写均可)"+"\n"+"\n空格键暂停"+"\n作者:Juni Zhu"+"\n微信:znix1116",font=('Yahei', 15),anchor="ne", justify="left")txt_lable.place(x = self.cell_size * self.col_cells + self.cell_size*2, y = self.cell_size*6)self.create_canvas()self.game_start()if __name__ == '__main__':Snake()

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

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

相关文章

python笔记—>贪吃蛇游戏制作

1、安装需要的库pygame Python Pygame 是一款专门为开发和设计 2D 电子游戏而生的软件包&#xff0c;它支 Windows、Linux、Mac OS 等操作系统&#xff0c;具有良好的跨平台性。Pygame 由 Pete Shinners 于 2000 年开发而成&#xff0c;是一款免费、开源的的软件包&#xff0…

手把手教你使用 Python 制作贪吃蛇游戏

贪吃蛇游戏是有史以来最受欢迎的街机游戏之一。在这个游戏中&#xff0c;玩家的主要目标是在不撞墙或不撞墙的情况下抓住最大数量的水果。在学习 Python 或 Pygame 时&#xff0c;可以将创建蛇游戏视为一项挑战。这是每个新手程序员都应该接受的最好的初学者友好项目之一。学习…

使用pygame制作贪吃蛇小游戏

使用pygame制作贪吃蛇小游戏 开发基本思路效果展示 具体实施步骤制作窗口&#xff0c;插入音频与图片绘制蛇与果实按键控制生成食物死亡设置其他设置 整体代码 开发基本思路 1、制作窗口&#xff0c;插入音频与图片 2、绘制蛇与果实 3、按键控制 4、生成食物 5、结束判断 效果…

应对新的挑战!ChatGPT将如何改变多域作战?

​公众号博主推送内容&#xff0c;未经许可&#xff0c;不得转载或者引用。 原文&#xff1a;Exploring the Possibilities of ChatGPT in Rugged Military AI Applications 《ChatGPT&#xff1a;利用最先进的技术支撑多域作战》 ChatGPT是一款基于GPT-3大型自然语言模型的…

Unity 接入巨量引擎今日头条广告投放SDK

巨量引擎 头条上报SDK接入 1.进入巨量引擎平台 ① 下载头条上报SDK SDK接入文档 我用的是5.3.0的官网上是3.3.12 SDK下载完了之后。 ②将unity工程导出android 工程。然后将下载的aar包导入UnityLibrary/libs文件夹下&#xff08;如图文件夹&#xff09; 并在改build.gradle文…

字节跳动 AI Lab 火山翻译在 WMT2022 非洲语向任务夺得桂冠

动手点关注 干货不迷路 1. 非洲语言的现状 非洲是世界上面积第二大的大洲&#xff0c;也是世界上第二个人口大洲&#xff0c;其大陆上存在 2146 种语言——约占世界语言总数的三分之一。广袤的面积、繁多的种族&#xff0c;还有宗教传播和殖民统治的影响&#xff0c;使其成为世…

Java开发经典面试题

重写与重载的区别重写与重载的区别_重写和重载_carrie呀carrie的博客-CSDN博客。。。。。。。。。。。https://blog.csdn.net/luoro/article/details/118307852?ops_request_misc%257B%2522request%255Fid%2522%253A%2522167875749216800211587145%2522%252C%2522scm%2522%253…

2023前端面试时遇到的面试题

2023前端面试时遇到的面试题 1.数组有哪些方法 push、pop、unshift、shift、join、forEach、filter、map、find… 2.filter和some返回的分别是一个什么 filter返回的是一个数组&#xff0c;some返回的是一个布尔值 3.es6新增了哪些方法 let和cconst、模板字符串&#xff…

Promise面试题

Promise面试题&#xff0c;带你搞懂同步异步执行顺序 前置知识面试题面试题一面试题二面试题三面试题四 分析面试题一分析面试题二分析面试题三分析面试题四分析 前置知识 Promise中的then方法 then&#xff1a;指定用于得到成功value的成功回调和用于得到失败reason的失败回调…

移动版OpenAI,手机的杀手还是救星?

AI登陆手机&#xff0c;难度因人而异。 原本小编还以为「2023年是属于元宇宙的一年」&#xff0c;实在没想到以ChatGPT为代表的AI技术能在这么短的时间内抢走元宇宙的风头&#xff0c;成为2023年的技术关键词。从OpenAI到搜索引擎、从绘图工具到游戏公司&#xff0c;几乎所有「…

领导讲话云山雾罩像糊弄鬼,这些职场潜规则你知道吗

上一篇&#xff1a;入职银行科技部半年&#xff0c;我已经丧失跳槽的能力了&#xff01; 混迹职场时间久了&#xff0c;就会发现领导职务越高&#xff0c;说话越有水平&#xff0c;也有高度&#xff0c;可是有时让你听的却是云山雾罩&#xff0c;不知道该如何应对。 聪明的人能…

代码的艺术(一)

目录 代码整洁的必要性 为什么要有代码 为什么要写得整洁 整洁的艺术 混乱的代价 整洁的定义 规整端正&#xff0c;符合规范 简洁精炼&#xff0c;便于阅读 什么是整洁的代码 怎样写出整洁的代码 不断改进 不要糊弄 具体做法 有意义的命名 使用函数 注释 勤加…

〖程序员的自我修养 - 优质简历篇①〗- 知己知彼,面试官是如何分析一份简历的

人之所以会觉得迷茫&#xff0c;本质上是欠缺对自己的一个控制力、识别庞杂信息、去伪存真的独立思考能力与认知能力。 说明&#xff1a;该文属于 程序员的自我修养 专栏&#xff0c;购买任意白宝书体系化专栏可加入易编程社区&#xff0c;早鸟价订阅模式除外。福利&#xff1a…

chatgpt赋能python:Python抠图教程:用代码实现高效抠图

Python 抠图教程&#xff1a;用代码实现高效抠图 什么是抠图&#xff1f; 在设计、美术、广告等领域中&#xff0c;经常需要把一张图片中的某个物体或人物单独提取出来&#xff0c;以便于进行后续的处理、叠加、合成等操作。这个过程就叫做抠图。 传统的抠图方式需要用到PS、…

ChatGPT大升级?它去考研能考上物理所吗?

3月15日本应是小编勤勤恳恳搬砖的平凡一天&#xff0c;但小编刚睡醒就发现朋友圈被ChatGPT刷屏了&#xff1a; 新版GPT-4震撼发布&#xff01; 大升级&#xff01;强到爆炸&#xff01; 这些字眼引起了我的兴趣&#xff0c;于是小编迅速入(ke)手(jin)了gpt-4&#xff0c;经过简…

快速构建一个简单的对话+问答AI (上)

文章目录 前言part0 资源准备基本功能语料停用词问答闲聊语料 获取 part01句的表达表达one-hot编码 词嵌入大致原理实现简单版复杂版如何训练 转换后的形状 part02 循环神经网络RNNRNN投影图RNN是三维立体的 LSTM&GRU part03意图识别分词FastText分类FastText网络结构优化点…

Postman请求具有拦截器(登录限制)接口

Postman请求具有拦截器&#xff08;登录限制&#xff09;接口 方法一&#xff1a;注释掉拦截器。 方法二&#xff1a;使用cookie信息 1.登录登陆页获取cookie信息 2.正式调用接口

postman访问提示限制

postman访问http://10.10.171.204:9090/platform/honda/addRtmVehicleTbox提示限制的原因&#xff1a; 被拦截 Websense 类别“Private IP Addresses”已筛选。解决办法&#xff1a; 关掉postman代理设置

PostMan如何模拟get请求

PostMan为调试接口提供了方便的操作&#xff0c;可以配置各种参数&#xff0c;那么使用postman如何模拟get请求&#xff0c;本文对此问题进行简要讲述。 工具/原料 Postman 方法/步骤 1 打开postman&#xff0c;创建一个新的请求。这两有两种方式创建&#xff0c;第一种&…

产研团队任务管理工具:盘点国内外9款知名任务管理系统软件

以下是10款国内外最知名的任务管理系统&#xff1a;1.研发项目任务管理-PingCode&#xff1b;2.通用项目任务管理-Worktile&#xff1b;3.免费开源研发任务工具-Redmine&#xff1b;4.海外著名项目任务管理工具-Asana&#xff1b;5.免费任务管理软件-Trello&#xff1b;6.个人任…