Firebase 版电子词典
学英语是许多 人一辈子的麻烦 。 所以本例中,我们开发一个英汉词典,用户执
行程序后,单击“翻译”按钮即可显示该单词的中文翻译 。
英汉词典标准版
因为这个案例的数据必须要存储在 Firebase 数据库中,所以我们先通过以下程
序来完成单词数据的导入。
数据导入
这个案例中将使用 csv 文件作为数据来源, csv 是一种通用而简单的数据格
式,我们首先利用程序把 eword.csv 文件中的英文单词全部保存至 Fire base 数据库的
English 节点中 。

from firebase import firebase

url = 'https://chiouapp01-74bde.firebaseio.com/English'
fb = firebase.FirebaseApplication(url, None)
datas=fb.get(url, None) def CkeckKey(no):
key_id=""
if datas != None:
for key in datas:
if no==datas[key]["eword"]: # 读取键名
key_id = key
break
return key_id ### 主程序从这里开始 ### with open('eword.csv','r', encoding = 'gbk') as f:
for line in f:
eword,cword = line.rstrip('\n').split(',')
word={'eword':eword,'cword':cword}
if CkeckKey(eword) == "": # 判断键是否存在
fb.post(url, word)
print(word)
print("\n转换完毕!")

自定义一个函数 menu , 用于实现主菜单显示。
def menu():
os.system("cls")
print("英 汉 词 典")
print("-------------------------")
print("1. 翻 译 单词")
print("2. 新 增 单词")
print("3. 显 示 单词")
print("4. 修 改 单词")
print("5. 删 除 单词")
print("0. 结 束 程 序")
print("-------------------------")
 自 定 义函数 CkeckKey ,实现根据 no 找到该条数据的 id ,注意参数
no 为字符串 类型 。
def CkeckKey(no):
key_id=""
if datas != None:
for key in datas:
if no==datas[key]["eword"]: # 读取键名称
key_id = key
break
return key_id
自定义函数 input_data ,可连续新增数据,按 Ente r 键后才会停止输
入并返回主菜单。
def input_data():
global datas
while True:
eword =input("请输入英文单词(Enter==>停止输入)")
if eword=="":
break
key_id = CkeckKey(eword)
if key_id != "": # 判断键是否存在
print("{} 单词已存在!".format(datas[key_id]))
continue
cword=input("请输入中文翻译:")
word={'eword':eword,'cword':cword}
key_id=fb.post(url, word)["name"]
time.sleep(2)
if datas == None:
datas = dict()
datas[key_id]=word
print("{}已被储存完毕".format(word))
数据输入成
功后会返回 一 个 diet 对象,并自动产生唯 一 编 号 ,通过 key_id=tb.
post(url, wo时)[”name”] 可以从 name 键中取得这个编号。
自 定义函数 disp_data , 实现以每页 15 条数据的分页显示效果 。
def disp_data():
global datas
datas=fb.get(url, None)
if datas != None:
n,page=0,15
for key in datas:
if n % page ==0:
print("单词\t中文翻译")
print("======================")
print("{}\t{}".format(datas[key]["eword"],datas[key]["cword"]))
n+=1
if n == page:
c=input("请按 Enter 显示下一页,Q 键返回主菜单")
if c.upper() == "Q":return
n=0
c=input("请按任意键返回主菜单")
自定义函数 search_data , 用于查询英文单词 。
def search_data():
while True:
eword =input("请输入要查询的英文单词(Enter==>停止输入)")
if eword=="": break
key_id = CkeckKey(eword)
if key_id != "": # 判断键是否存在
print("中文翻译:{}".format(datas[key_id]["cword"]))
else:
print("{} 单词不存在!\n".format(eword))
input("请按任意键继续翻译…")
自定义函数 edit data ,用于修改英文单词。
def edit_data():
while True:
eword =input("请输入要修改的英文单词(Enter==>停止输入)")
if eword=="":
break
key_id = CkeckKey(eword)
if key_id != "": # 判断键是否存在
print("原来中文翻译:{}".format(datas[key_id]["cword"]))
cword=input("请输入中文翻译:")
word={'eword':eword,'cword':cword}
datas[key_id]=word
fb.put(url + '/', data=word, name=key_id)
time.sleep(2)
print("{} 已修改完毕\n".format(word))
else:
print("{} 未建立!\n".format(eword))
自定义函数 delete data ,实现单词的删除。
def delete_data():
while True:
eword =input("请输入要删除的英文单词(Enter==>停止输入)")
if eword=="":
break
key_id = CkeckKey(eword)
if key_id != "": # 判断键是否存在
print("确定删除{}的数据!:".format(datas.get(key_id)))
yn=input("(Y/N)?")
if (yn=="Y" or yn=="y"):
fb.delete(url + '/' + key_id,None)
datas.pop(key_id)
print("数据删除完毕\n")
else:
print("{} 单词不存在!\n".format(eword))
创建 Firebase 数据库连接 。
### 主程序从这里开始 ###

import time,os
from firebase import firebase url = 'https://chiouapp01-74bde.firebaseio.com/English'
fb = firebase.FirebaseApplication(url, None)
datas=fb.get(url, None) while True:
menu()
choice = input("请输入您的选择:")
try:
choice = int(choice)
if choice==1:
search_data()
elif choice==2:
input_data()
elif choice==3:
disp_data()
elif choice==4:
edit_data()
elif choice==5:
delete_data()
else:
break
except:
print("\n非法按键!")
time.sleep(1)
print("程序执行完毕!")

吴裕雄--天生自然python学习笔记:python 用firebase实现英文电子词典的更多相关文章

  1. 吴裕雄--天生自然HADOOP学习笔记:hadoop集群实现PageRank算法实验报告

    实验课程名称:大数据处理技术 实验项目名称:hadoop集群实现PageRank算法 实验类型:综合性 实验日期:2018年 6 月4日-6月14日 学生姓名 吴裕雄 学号 15210120331 班 ...

  2. 吴裕雄--天生自然MySQL学习笔记:MySQL UPDATE 更新

    如果需要修改或更新 MySQL 中的数据,我们可以使用 SQL UPDATE 命令来操作. 语法 以下是 UPDATE 命令修改 MySQL 数据表数据的通用 SQL 语法: UPDATE table ...

  3. 吴裕雄--天生自然MySQL学习笔记:MySQL 插入数据

    MySQL 表中使用 INSERT INTO SQL语句来插入数据. 可以通过 mysql> 命令提示窗口中向数据表中插入数据,或者通过PHP脚本来插入数据. 以下为向MySQL数据表插入数据通 ...

  4. 吴裕雄--天生自然MySQL学习笔记:MySQL简介

    MySQL 是最流行的关系型数据库管理系统,在 WEB 应用方面 MySQL 是最好的 RDBMS(Relational Database Management System:关系数据库管理系统)应用 ...

  5. 吴裕雄--天生自然 oracle学习笔记:oracle理论学习详解及各种简单操作例子

    1. 数据库的发展过程 层次模型 -->网状模型 -->关系模型 -->对象关系模型 2. 关于数据库的概念 DB:数据库(存储信息的仓库) DBMS:数据库管理系统(用于管理数据库 ...

  6. 吴裕雄--天生自然HADOOP学习笔记:基本环境配置

    实验目的 学习安装Java 学习配置环境变量 学习设置免密码登陆的方法 掌握Linux环境下时间同步的配置 实验原理 1.Java的安装 java是大数据的黄金语言,这和java跨平台的特性是密不可分 ...

  7. 吴裕雄--天生自然HADOOP学习笔记:使用yum安装更新软件

    实验目的 了解yum的原理及配置 学习软件的更新与安装 学习源代码编译安装 实验原理 1.编译安装 前面我们讲到了安装软件的方式,因为linux是开放源码的,我们可以直接获得源码,自己编译安装.例如: ...

  8. 吴裕雄--天生自然HADOOP学习笔记:Shell工具使用

    实验目的 学习使用xshell工具连接Linux服务器 在连上的服务器中进入用户目录 熟悉简单的文件操作命令 实验原理 熟悉shell命令是熟悉使用linux环境进行开发的第一步,我们在linux的交 ...

  9. 吴裕雄--天生自然HTML学习笔记:HTML 布局

    网页布局对改善网站的外观非常重要. 请慎重设计您的网页布局. <!DOCTYPE html> <html> <head>  <meta charset=&qu ...

  10. 吴裕雄--天生自然MySQL学习笔记:MySQL 安装

    所有平台的 MySQL 下载地址为: MySQL 下载:https://dev.mysql.com/downloads/mysql/ 注意:安装过程我们需要通过开启管理员权限来安装,否则会由于权限不足 ...

随机推荐

  1. part11 Vue项目接口联调//真机测试

    何为项目接口联调? 前端代码编译好了  后端接口写好了 我们就需要去掉前端模拟数据干掉 用后端提供的数据.进行前后端的一个调试 如何联调? config目录下面 index.js 文件 dev 中pr ...

  2. 高性能集群软件keepalived

     Keepalived介绍 以下是keepalive官网上的介绍.官方站点为http://www.keepalived.org.         Keepalived is a routing sof ...

  3. h5-多列布局

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

  4. 68.ORM查询条件:date,time,year,week_day等

    1. date: 首先查看数据库中article表的信息,由表中的create_time字段可以看出时间为2020.2.5 打印出查询的结果: <QuerySet []>:但是查询的结果为 ...

  5. “杀死”纸质名片!HiHello能重构商业关系网吗?

    在当下的互联网时代,要添加好友去扩大自己的社交圈似乎是再简单不过.随便点击一个微信名片.与其他网友互相关注微博等,好像就又搭建了一个社交节点.暂且不讨论这些好友关系的质量问题,单是这样的方式并不适合于 ...

  6. elasticsearch-集群管理

    1.集群结构 ES 通常以集群方式工作.以提高搜索性能.容错能力.高可用.实现PB级数据搜索. 相关概念: (1)结点: ES集群由多台ES服务器组成.每个ES 服务端就是个一个NODE结点 (2)分 ...

  7. CSS3-选中的锚链接改变指定样式

    1.css样式 主角就是:target <a> 标签的 target 属性规定在何处打开链接文档,连接文档也可以是一个样式. 如果在一个 <a> 标签内包含一个 target ...

  8. Python笔记_第四篇_高阶编程_检测_2.文档检测

    1. 文档检测: 我们观察官方的函数编写的时候会在函数或者类当中有些类的备注,这些备注叫做文档.当我们在编写函数的时候,可以去显示这些文档.因此我们可以用这个文档来进行检测.另外我们还需要导入doct ...

  9. TF利用分布式队列控制线程

    假设分布式任务包含n个ps节点, m个worker节点. m, n>0. 希望所有worker的任务结束后,所有节点才终止. 方法: 借助队列tf.FIFOQueue实现. 原理: tf.FIF ...

  10. spring获取当前动态代理对象

    由于spring中的aop拦截的是代理对象 当拦截的目标方法被本类的另一个方法调用时,会出现拦截失效 最佳实践: 例如拦截RegulationService的update(regulation)方法, ...