Python 程序通过 python-firebase 包可以存取 Firebase 数据库。
使用 python-firebase 包
首先必须安装 python-firebase 包,安装方法如下:

 firebase 对象的方法
利用 firebase 对象方法可以对数据库进行操作,包括新增 、修改和删除数据。
fire base 提供了下列方法:

from firebase import firebase

url = 'https://chiouapp01-74bde.firebaseio.com/'
fb = firebase.FirebaseApplication(url, None)
#fb.post('/test', "Python")
fb.post('/test', {"name":"David"})

我们也可以创建 diet 类型的数据:

成功创建的数据会返回一个 diet 对象,并自动产生一个唯一编号,数据的查询、
编辑或删除都必须根据这个编号。我们可以从返回值的 name 键中取得这个编号。
from firebase import firebase

url = 'https://chiouapp01-74bde.firebaseio.com'
fb = firebase.FirebaseApplication(url, None)
dict1 = fb.post('/test', {"name":"David"})
print(dict1["name"]) # -KTMkuwiNbE18j9zpzko

增数据前需要先检查数据是否己存在,这一点后面我们还会详细说明 。
现在,我们再做一些稍微复杂 的操作 : 在 s tud ents 节点一次创建三条数据,而且
每一条数据中都要包括 name 和 no 两个字段 。

from firebase import firebase

students = [{'no':1 ,'name':'李天龙'},{'no':2,'name':'高一人'},{'no':3,'name':'洪大同'}]

url = 'https://chiouapp01-74bde.firebaseio.com'
fb = firebase.FirebaseApplication(url, None) for student in students:
fb.post('/students', student)
print("{} 存储完毕".format(student))

get 方法用 于读取指定 url 节点 的 数据 ,如果成功返回 diet 类型数据,第 2 个参
数设为 None ,会返回节点 的所有数据, 也可以设为一个 id 来返回指定 id 的数据。
例如 : 读取 students 节点 的数据 。
import time
from firebase import firebase url = 'https://chiouapp01-74bde.firebaseio.com'
fb = firebase.FirebaseApplication(url, None)
students = fb.get('/students', None)
for key,value in students.items():
print("id={}\tno={}\tname={}".format(key,value["no"],value["name"]))
time.sleep(1)

首先,把所有数据读取到 data s 字典变量中 。

然后我们再定义一个从 no 键中根据 no 的值来查询该数据 id 的 自定义函数,如
果数据存在则返回其 i d (也就是 Key );否则就返回空字符串 。

利用 Ckeck:Key ()方法可以判断数据是否存在,并加以删除。 例如,若 no=l 的数据存在,就把它删除:

执行程序后,我们可看到 2 号数据己被删除 。

def CkeckKey(no):
key_id=""
if datas != None:
for key in datas:
if no==datas[key]["no"]: # 如果找到键名称,则......
key_id = key
break
return key_id ### 主程序从这里开始 ### from firebase import firebase url = 'https://chiouapp01-74bde.firebaseio.com'
fb = firebase.FirebaseApplication(url, None) while True:
datas=fb.get('/students', None)
no = input("请输入序号(Enter==>停止输入)")
if no=="":
break
key_id = CkeckKey(int(no))
if key_id != "": # 判断键是否存在
print("确定要删除{}的数据?".format(datas[key_id]["name"]))
yn=input("(Y/N)?")
if (yn=="Y" or yn=="y"):
fb.delete('/students/'+key_id,None)
print("数据删除完毕\n")
else:
print("{} 对应的数据不存在!\n".format(no))

from firebase import firebase

url = 'https://chiouapp01-74bde.firebaseio.com'
fb = firebase.FirebaseApplication(url, None)
fb.put(url + '/test/', data={"name":"Lin"}, name="mykey")

from firebase import firebase

url = 'https://chiouapp01-74bde.firebaseio.com'
fb = firebase.FirebaseApplication(url, None)
fb.put(url + '/test/', data={"name":"Mary"}, name="mykey")

def CkeckKey(no):
key_id=""
if datas != None:
for key in datas:
if no==datas[key]["no"]: # 如果找到键名,则......
key_id = key
break
return key_id ### 主程序从这里开始 ###
import time
from firebase import firebase url = 'https://chiouapp01-74bde.firebaseio.com'
fb = firebase.FirebaseApplication(url, None)
datas=fb.get('/students', None) while True:
no = input("请输入编号(Enter==>停止输入)")
if no=="": break
key_id = CkeckKey(int(no))
if key_id != "": # 判断键是否存在
print("原来姓名:{}".format(datas[key_id]["name"]))
name=input("请输入姓名:")
data = {"no":int(no),"name":name}
datas[key_id]=data
fb.put(url + '/students/', data=data, name=key_id)
time.sleep(2)
print("{} 已修改完毕\n".format(data))
else:
print("{} 对应的数据不存在!\n".format(no))

def CkeckKey(no):
key_id=""
if datas != None:
for key in datas:
if no==datas[key]["no"]: # 如果找到键名,则...
key_id = key
break
return key_id ### 主程序从这里开始 ### from firebase import firebase students = [{'no':1 ,'name':'李天龙'},{'no':2,'name':'高一人'},{'no':3,'name':'洪大同'}] url = 'https://chiouapp01-74bde.firebaseio.com'
fb = firebase.FirebaseApplication(url, None) datas=fb.get('/students', None) for student in students:
no=student["no"] # 读取键名称
if CkeckKey(no) == "": # 判断键是否存在
fb.post('/students', student)
print("{} 储存完毕".format(student))

吴裕雄--天生自然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. Vue组件template模板字符串几种写法

    在定义Vue组件时,组件的模板template选项需要的是一个字符串,当其内容较复杂需要换行时,需要简单处理一下,具体有五种方式: 方式一:使用 \ 转义换行符 <!DOCTYPE html&g ...

  2. LeetCode刷题笔记(1-9)

    LeetCode1-9 本文更多是作为一个习题笔记,没有太多讲解 1.两数之和 题目请点击链接 ↑ 最先想到暴力解法,直接双循环,但是这样复杂度为n平方 public int[] twoSum(int ...

  3. 51nod 1421:最大MOD值

    1421 最大MOD值 题目来源: CodeForces 基准时间限制:1 秒 空间限制:131072 KB 分值: 80 难度:5级算法题 有一个a数组,里面有n个整数.现在要从中找到两个数字(可以 ...

  4. Ubuntu16.04 faster-rcnn+caffe+gpu运行环境配置以及解决各种bug

    https://blog.csdn.net/flygeda/article/details/78638824 本文主要是对近期参考的网上各位大神的博客的总结,其中,从安装系统到跑通程序过程中遇到的各种 ...

  5. 关于win10 使用eclipse如何配置环境变量

    关于环境变量的配置,在百度上有很多教程,但对于我来说完成这步操作确实不简单,所以决定在这里分享一下配置方法. 1.安装好jdk/jre.  官网都有安装文件,仔细一些,就能安装成功,可以自定义安装路径 ...

  6. maven项目集成Quartz定时任务框架,实现批处理功能

    一.Quartz简介 主要做定时任务,即:在指定时间点或时间段,执行某项任务,可设置执行次数.时间间隔等. 二.Springcloud简介 对比传统的.庞大的.复杂的.以ssm或ssh为框架的web项 ...

  7. LeetCode——973. 最接近原点的 K 个点

    我们有一个由平面上的点组成的列表 points.需要从中找出 K 个距离原点 (0, 0) 最近的点. (这里,平面上两点之间的距离是欧几里德距离.) 你可以按任何顺序返回答案.除了点坐标的顺序之外, ...

  8. 微信支付第三方sdk使用

    1.引入依赖:(对于依赖冲突自行解决) <dependency> <groupId>com.github.binarywang</groupId> <arti ...

  9. 黑马_13 Spring Boot:01.spring boot 介绍&&02.spring boot 入门

    13 Spring Boot: 01.spring boot 介绍&&02.spring boot 入门 04.spring boot 配置文件 SpringBoot基础 1.1 原有 ...

  10. python-day4爬虫基础之正则表达式

    正则表达式:(字符串匹配) 使用单个字符串来描述匹配一系列符合某个句法规则的字符串 是对字符串操作的一种逻辑公式 应用场景:处理文本和数据 正则表达式过程:依次拿出表达式和文本中的字符比较,如果每一个 ...