小学生python游戏编程arcade----单词对错检测及记录写入excel中

  • 前言
  • 单词对错检测及记录写入excel中
    • 1、excel读取修改
      • 1.1 excel读取
      • 1.2 修改用到的库
      • 1.3 获取Excel表格名称的三种方式
      • 1.4 excel格式问题
    • excel文件保存
      • 2.1 保存函数
      • 2.2 实验
      • 2.3 游戏中调用修改
      • 2.4 升级时保存字典内容至excel
  • 源码获取

前言

接上篇文章继续解绍arcade游戏编程的基本知识。在游戏中将单词的对错记录写入excel中,游戏碰撞中如何收集每个单词的掌握情况,游戏中对excel文件的操作知识。

单词对错检测及记录写入excel中

1、excel读取修改

1.1 excel读取

def getwordzw(filename, sheet_index=0, danyuan=1,nianji=‘三年级上册’):
# 打开excel文件读取数据,取两列存为字典
data = xlrd.open_workbook(filename)
table = data.sheet_by_index(sheet_index)
nrows = table.nrows
# nclos = table.ncols
# 将每行的信息放入一个字典,再将字典放入一个列表中
dict = {}
for rownum in range(1, nrows):
# print(int(table.cell_value(rownum, 5)))
if table.cell_value(rownum, 5)== danyuan and table.cell_value(rownum, 6)==nianji:
# print(‘true’)
dict[table.cell_value(rownum, 1).replace(‘\u200e’, ‘’)] = {
‘hanzi’:table.cell_value(rownum, 4).replace(‘\u200e’, ‘’),
‘cuo’: table.cell_value(rownum, 7),
‘dui’: table.cell_value(rownum, 8),
‘id’:rownum
}

return dict

1.2 修改用到的库

openpyxl

1.3 获取Excel表格名称的三种方式

获取Excel表格名称的三种方式
sheet = workbook[“花名册”] #根据表名获取表格
sheet2 = workbook.worksheets[0] #根据索引在worksheets中获取表格
sheet3 = workbook.active #获取当前活跃的表

1.4 excel格式问题

# 保存excel数据
data = load_workbook(filename)

File “E:\pgame\venv\lib\site-packages\openpyxl\reader\excel.py”, line 94, in _validate_archive
raise InvalidFileException(msg)
openpyxl.utils.exceptions.InvalidFileException: openpyxl does not support the old .xls file format, please use xlrd to read this file, or convert it to the more recent .xlsx file format.
如原先用的93-97的excel格式,出错以上错误,用新的.xlsx的excel格式,正常

excel文件保存

2.1 保存函数

def saveword(wordzd,filename, sheet_index=3, danyuan=1,nianji='三年级上册'):# 保存excel数据data = load_workbook(filename)table = data.worksheets[sheet_index]# cell与读取时开始位不一样,cell 从1,1开始for w in wordzd:print(wordzd[w]['id'])print(table.cell(wordzd[w]['id']+1, 8).value)table.cell(wordzd[w]['id']+1, 8).value=wordzd[w]['cuo']table.cell(wordzd[w]['id'] + 1, 9).value = wordzd[w]['cuo']data.save(filename)

2.2 实验

游戏中,每次升级时,把打对错的单词,在excel中保存记录次数,等玩一段时间后,把不会的单词找出来,再进行生产敌人。

    zd={'pen': {'hanzi': '钢笔', 'cuo': 3, 'dui': 0.0, 'id': 1}, 'pencil': {'hanzi': '铅笔', 'cuo': 2, 'dui':2, 'id': 2}, 'pencil-case': {'hanzi': '铅笔盒', 'cuo': 4, 'dui': 0.0, 'id': 3}, 'ruler': {'hanzi': '尺子', 'cuo': 0.0, 'dui': 0.0, 'id': 4}}saveword(zd,u'english.xlsx', sheet_index=3, danyuan=1, nianji='三年级上册')

2.3 游戏中调用修改

生产敌人时

    def setup_enemy(self):# passself.scene.add_sprite_list_after(LAYER_tanks, 'wj')if len(self.word_keys) == 0:if self.danyuan==len(self.gk[self.year]):self.level += 1self.year =self.years[self.level]else:self.danyuan += 1self.setup_word(self.danyuan, self.year)if len(self.word_keys) > 0:self.key = self.word_dict[self.word_keys[0]]['hanzi']  # 朋友# print('key',self.key)xsword = {}xsword[self.word_keys[0]] = self.word_dict[self.word_keys[0]]['hanzi']# 随机取3sankey = random.sample(self.word_dict.keys(), 3)if self.word_keys[0] in sankey:sankey.remove(self.word_keys[0])# 增加两个敌人xsword[sankey[0]] = self.word_dict[sankey[0]]['hanzi']xsword[sankey[1]] = self.word_dict[sankey[1]]['hanzi']

坦克直撞时检测:

        # 检测磁到的是硬币还是敌人for collision in player_collision_list:if self.scene[LAYER_tanks] in collision.sprite_lists:collision.remove_from_sprite_lists()arcade.play_sound(self.hit_sound3)if collision.hz == self.key:self.score += 50self.wanjia.bullets += 3self.word_dict[self.word_current]['dui'] += 1self.enemy_reset = Truereturnelse: # 撞错了减两命self.wanjia.life -= 2self.word_dict[collision.word]['cuo'] += 1self.word_dict[self.word_current]['cuo'] += 1if self.wanjia.life <= 0:arcade.play_sound(self.game_over)game_over = GameOverView()self.window.show_view(game_over)return

子弹碰撞时检测:

            if hit_list:bullet.remove_from_sprite_lists()for cc in hit_list:# 敌坦克与子弹碰撞if (self.scene[LAYER_tanks] in cc.sprite_lists):# 磁撞的是敌人 根据子弹伤害及敌人生命值确定争分数及消失cc.remove_from_sprite_lists()# 声音arcade.play_sound(self.hit_sound1)# 爆炸效果self.baozha(hit_list)if cc.hz == self.key:self.score += 100self.wanjia.bullets += 5self.enemy_reset = Trueself.word_dict[self.word_current]['dui'] +=1returnelse:self.wanjia.life -= 2self.word_dict[cc.word]['cuo'] += 1self.word_dict[self.word_current]['cuo'] += 1# print('打错了')if (self.scene['建筑物'] in cc.sprite_lists):# 磁撞的是建筑物,  制造爆炸for i in range(20):particle = Particle(self.scene[LAYER_explosions])particle.position = cc.position  # 粒子位置,也即敌人位置self.scene[LAYER_explosions].append(particle)smoke = Smoke(30)smoke.position = cc.position  # 烟雾位置self.scene[LAYER_explosions].append(smoke)cc.remove_from_sprite_lists()# 爆炸声音arcade.sound.play_sound(self.hit_sound2)return

2.4 升级时保存字典内容至excel

    def collision_all(self):self.collision_bullet_enemy()self.collision_bullet_player()self.collision_player_enemy()if self.enemy_reset:# 重置坦克及子弹self.scene.remove_sprite_list_by_name(LAYER_bullet)self.scene.remove_sprite_list_by_name(LAYER_tanks)self.scene.add_sprite_list_after(LAYER_bullet, 'wj')self.scene.add_sprite_list_after(LAYER_tanks, 'wj')if len(self.word_keys)==0:saveword(self.word_dict,u'english.xls', sheet_index=3, danyuan=self.danyuan, nianji=self.year)print('升级成功')self.update_stop = True# self.setup_texiao()return# arcade.draw_text('升级成功', self.wanjia.center_x, self.wanjia.center_y + 40, arcade.csscolor.RED, 18, )# time.sleep(10)self.setup_enemy()self.enemy_reset = False

源码获取

关注博主后,私聊博主免费获取
需要技术指导,育娃新思考,企业软件合作等更多服务请联系博主

今天是以此模板持续更新此育儿专栏的第 38/50次。
可以关注我,点赞我、评论我、收藏我啦。

小学生python游戏编程arcade----单词对错检测及记录写入excel中相关推荐

  1. 小学生python游戏编程arcade----坦克大战2

    小学生python游戏编程arcade----坦克大战2 前言 多摄象头显得分,title地图加载,精灵分层管理,移动精灵 1.提示框制作 1.1养眼绿色 1.2 画距形提示框 1.3 效果图 1.4 ...

  2. 小学生python游戏编程arcade----坦克大战4

    小学生python游戏编程arcade----坦克大战4 前言 坦克大战4 1.1 每单元英语单词学完升级效果 1.2 单词调用及敌坦克随机问题 1.3 效果图 1.4 代码实现 源码获取 前言 接上 ...

  3. 小学生python游戏编程2----飞机大战1

    小学生python游戏编程2----飞机大战1 前言 主要设计 1.界面设计 2.动态背景 3.记分的实现 4.射击游戏功能的实现 5.声音的实现 应用知识点 1.python知识点 1.1 角色创建 ...

  4. 小学生python游戏编程arcade----excel调用

    小学生python游戏编程arcade----excel调用 前言 小学生python游戏编程arcade----excel调用 1.excel文件 1.1 excel表头 1.2 excel文件 1 ...

  5. 小学生python游戏编程arcade----基本知识3

    小学生python游戏编程arcade----基本知识3 前言 多摄象头显得分,title地图加载,精灵分层管理,移动精灵 1.多摄象头显得分 1.1得分 1.2 两个摄象机的绘制 1.3 效果图 1 ...

  6. 小学生python游戏编程arcade----可旋转的坦克的发射子弹

    小学生python游戏编程arcade----可旋转的坦克的发射子弹 前言 小学生python游戏编程arcade----可旋转坦克的发射子弹 1.可旋转坦克的发射子弹 1.1 子弹的类 1.2 发射 ...

  7. 小学生python游戏编程arcade----动画图片实现爆炸效果

    小学生python游戏编程arcade----动画图片实现爆炸效果 前言 动画图片实现爆炸效果 1.爆炸类的的实现 1.1爆炸图片 1.2 类的定义 1.3 爆炸类的引用 1.4 爆炸类的更新 1.5 ...

  8. 小学生python游戏编程arcade----爆炸粒子类

    小学生python游戏编程arcade----爆炸粒子类 前言 1.1 参数设置 粒子加速下降的速度.如果不需要,则为0 粒子退出的速度 粒子移动的速度.范围为2.5<-->5,设置为2. ...

  9. 小学生python游戏编程arcade----基本知识1

    小学生python游戏编程arcade----基本知识 前言 基本知识 1.简单窗体 2.试着添加角色及背景 3.场景 4.角色控制及物理引擎 总结 源码获取 前言 前面章节分享试用了pyzero,p ...

最新文章

  1. linux数组删除数据,JavaScript在数组的循环中删除元素
  2. linux c va_list 32位和64位的差异
  3. linux netlink 编程示例(一)内核端
  4. springboot redis token_Spring Boot+Redis 扛住,瞬间千次重复提交(实例)
  5. 【报告分享】2020中国短视频行业洞察报告.pdf(附下载链接)
  6. ajax无法发送json串,如何使用$ .ajax发送JSON而不是查询字符串?
  7. 12、Java函数接口
  8. Android Studio导入项目运行出现大量警告,且报错GC,解决办法
  9. SQL安装步骤及可能遇到的错误
  10. Gps开发实战——卫星数量获取
  11. 刚体运动学公式_1.力的观点 ⑴.匀变速直线运动中常见的公式: 牛顿第二定律: 运动学公式:.... ⑵.圆周运动的主要公式:...
  12. Lattice LSTM
  13. 计算机创造奇迹的英语作文,大学英语作文:创造奇迹 Creating Miracle
  14. 分析了网易云数十万歌单后写出2020年的最全歌单推荐
  15. List 过滤、排序、校验等处理方法
  16. 想通过参加会议年入30万,没这些能力可不行——百格活动
  17. cuda多版本管理和分类、运行时cuda、驱动cuda
  18. 最详细破解nessus(windows)教程 插件更新至20220830
  19. fluke福禄克8000|8508A|8808A|8845A|8846A数字万用表软件NS-Multimeter
  20. 简单方便Zalo营销群控

热门文章

  1. 迪赛智慧数——饼图(基本饼图):诈骗类型占比
  2. java emmet插件安装_Emmet插件的使用
  3. Nautilus Chain 首个生态基础设施 Poseiswap,公布空投规则
  4. elementUI按esc关闭对话框
  5. oracle数据库offline,oracle中删除offline状态的数据文件
  6. Caused by: java.sql.SQLException: Value ‘0000-00-00 00:00:00‘ can not be represented as java.sql.Tim
  7. 【芯片前端】D触发器的功耗的直观分析图
  8. 计算机的内存和cpu,内存与CPU二者之间的关系_Intel服务器CPU_服务器产业-中关村在线...
  9. 理解进程、线程以及上下文切换
  10. 用oracle的merge实现mysql的replace into