MongoDB实验——数据库基本操作(头歌)
Posted 海浪~&
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了MongoDB实验——数据库基本操作(头歌)相关的知识,希望对你有一定的参考价值。
第1关:创建数据库
命令行
mongo
use mydb
db.mydb.insert(_id:1,name:"李小红")
第2关:创建集合
命令行输入:
mongo
use Testdb2
db. t_stu.insert([_id:1,name:"小明",sex: "男",hobbies: ["乒乓球","羽毛球"],
_id:2,name:"小红",sex: "女",hobbies: ["画画","唱歌"]])
第3关:文档操作一
命令行输入:
mongo
use Testdb3
document=([_id:1,name:"张小华",sex: "男",phone: "12356986594",hobbies: ["打篮球","踢足球","唱歌"]]);
db.stu1.insert(document)
db.stu2.insert(document)
db.stu3.insert(document)
db.stu2.update(phone: "12356986594",$set: phone: "18356971462")
db.stu3.save(_id:1,name:"张晓晓",sex: "女",phone: "12365498704",hobbies: ["跳舞","羽毛球","唱歌"])
第4关:文档操作二
命令行
mongo
document=([
name:'张小华',
sex:'男',
age:20,
phone:'12356986594',
hobbies:['打篮球','踢足球','唱歌']
,
name:'李小红',
sex:'女',
age:18,
phone:'12355487536',
hobbies:['跳舞','唱歌']
])
db.stu1.insert(document)
代码文件
#********* Begin *********#
echo "
document=([
_id:1,name:'西西',sex:'女',age:23,national:'汉族',
_id:2,name:'东东',sex:'男',age:20,national:'苗族',
_id:3,name:'北北',sex:'男',age:19,national:'汉族',
_id:4,name:'南南',sex:'女',age:15,national:'傣族']);
db.stu1.insert(document);
db.stu2.insert(document);
db.stu1.find('age':\\$gte:15,'sex':'女');
db.stu1.find('national':'苗族');db.stu1.find('age':\\$lt:20,'sex':'男');
db.stu2.remove();
"
#********* End *********#
第5关:综合实训——学生信息管理
(先复制代码文件,再来按顺序输命令行)
命令行(分步骤顺序运,不然会报错)
1. mongo --port 27017
2. use Testdb5
3. document=([_id:1,name:"王晓丽",age:19,sex:"女",major:"计算机", _id:2,name:"张明",age:21,sex:"男",major:"计算机",
_id:3,name:"秋雅",age:20,sex:"女",major:"播音主持",
_id:4,name:"张欣欣",age:18,sex:"女",major:"计算机",
_id:5,name:"袁华",age:20,sex:"男",major:"播音主持",
_id:6,name:"马冬梅",age:20,sex:"女",major:"表演",
_id:7,name:"夏洛",age:22,sex:"男",major:"表演",
_id:8,name:"李大春",age:23,sex:"男",major:"表演"]);
4. db.student_t.insert(document);
代码文件
#********* Begin *********#
echo "
db.student_t.save('_id':4,'name':'张欣欣','age':18,'sex':'女','major':'播音主持');db.student_t.find('age':\\$gte:20);db.student_t.find('sex':'男');db.student_t.find('major':'播音主持');db.student_t.find('major':'表演','sex':'女');db.student_t.find('_id':5);db.student_t.find('name':'王晓丽');
"
#********* End *********#
头歌实验五Python循环结构
文章目录
>>>第1关:达依尔的麦子数
- 任务描述
- 案例分析
- 相关知识
- for循环
任务描述
本关任务: 相传古印度宰相达依尔,是国际象棋的发明者。 有一次,国王因为他的贡献要奖励他,问他想要什么.达依尔说:”只要在国际象棋棋盘上(共64格)摆上这么些麦子就行了:第一格一粒,第二格两粒,……,后面一格的麦子总是前一格一麦子数的两倍,摆满整个棋盘,我就感恩不尽了。 编写程序,根据输入的格子数,计算国王要付给达依尔的麦子数。
案例分析
输入n值 处理 s初值为0(累计的麦子数) x初值为1(格子上的麦子数) 循环n次 每次将麦子数x累加到s中 x赋值为x的2倍 输出s值
相关知识
为了完成本关任务,你需要掌握: for循环
for循环
在python中,对于for循环,可以设置遍历结构为range函数 for i in range(初值,终值): <语句块>
i从初值取值到终值-1,每次执行一次循环体
测试说明
平台会对你编写的代码进行测试:
测试输入:6 预期输出: 麦子数63
测试输入:1; 预期输出: 麦子数1
测试输入:10; 预期输出: 麦子数1023
参考答案
n = eval(input())
# 代码开始
s = 1 # 累计的麦子数
x = 1 # 格子上的麦子数
for i in range(x, n):
x = x * 2
s = s + x;
print('麦子数%d' % s, end='')
# 代码结束
>>>第2关:四级单词查询
- 任务描述
- 案例分析
- 相关知识
- 如何处理文件
- 文件打开
- 文件循环
- 文件关闭
- 遍历文件
- 如何处理文件
- 测试说明
任务描述
本关任务: 大学英语四级考试,即CET-4,College English Test Band 4的缩写,是由国家教育部高等教育司主持的全国性英语考试。 英语四级大纲要求的词汇量是4500个词,是英语备考的关键。 《四级词汇.txt》文件如图所示,每行显示一个单词及其中文释义。 编写一个程序,输入一个单词(英文或中文),将所有包含该单词的行显示出来,并统计共有几个。 若该单词不存在,则显示没有此单词。
案例分析
1.输入需要查询的单词,计数器置0 2.打开文件,对文件每行遍历 若该行包含需要查询的单词,则输出该行,计算器加一 3.文件遍历结束后,若计数器为0,输出没有查询结果,否则输出计数器的值 4.关闭文件
相关知识
为了完成本关任务,你需要掌握:1.如何处理文件,2.如何对文件循环。
如何处理文件
文件打开
语法格式: <file对象名>=open(<文件名>,<打开模式>,<encoding=编码格式>) Python内置的open()函数打开一个文件,创建一个file对象。 文件名是字符型数据。 若文件在当前文件夹下,直接输入文字的名字,若在其他文件夹下,还需写出文件的路径。 打开模式有只读(“r”),写入(“w”),追加(“a”)等。 默认文件访问模式为只读®。 以只读方式打开文件,只能读取文件的内容,不能修改文件。 只读方式打开文件,文件的指针将会放在文件的开头。
文件循环
for <循环变量> in 文件 : <循环体> 从文件的第一行到文件的最后一行,依次读取每行的文字到循环变量,执行循环体后,读取下一行
文件关闭
<file对象名>.close() 对文件处理完成以后,使用文件对象.close()方法来关闭文件。
遍历文件
语法格式: for <循环变量> in 文件 : <循环体> 从文件的第一行到文件的最后一行,依次读取每行的文字到循环变量,执行循环体后,读取下一行
测试说明
平台会对你编写的代码进行测试:
测试输入:天空 预期输出: heaven n.天堂;天,天空 sky n.天,天空 共有2个单词
测试输入:sky 预期输出: sky n.天,天空 whisky n.威士忌酒 共有2个单词
测试输入:sky 预期输出: sky n.天,天空 whisky n.威士忌酒 共有2个单词
测试输入:syk 预期输出: 没有此单词
word = input("输入单词")
f1 = open("sy5//四级词汇.txt", "r")
s = 0
# 代码开始
for i in f1:
if i.find(word) != -1:
s += 1
print(i, end='')
if s != 0:
print('共有%d个单词' % s, end='')
else:
print("没有此单词")
f1.close()
# 代码结束
第3关:出租车车费计算
- 任务描述
- 案例分析
- 相关知识
- 循环计算
- 判断白天或晚上
- 计算低速运行费用
- 测试说明
任务描述
某地出租车计费程序,规则如下: 白天起步2公里内8元,2公里以上续程单价每公里为2.0元, 夜间(22:00一次日5:30)2公里内10元,2公里以上续程单价每公里为2.40元。 此外,还要附加低速计时收费。在时速12公里/小时(含12公里/小时)以下,累计每满2分钟计费1元。 本官任务:编写程序,输入打车的时间,公里数和低速行驶的时间(分钟),计算车费。要求能循环计算 示例如下: 请输入打车时间(小时:分钟)9:0 请输入里程5 请输入低速行驶时间(分钟)10 车费是19.00元 是否继续(y/n)y 请输入打车时间(小时:分钟)22:15 请输入里程6 请输入低速行驶时间(分钟)1 车费是19.60元 是否继续(y/n)n
案例分析
1.循环变量初值为y 2.如果循环变量为y或Y,则执行下列操作 3.输入打车的时间:小时和分钟、里程和低速运行时间 4.根据小时和分钟,判断是白天还是夜间 如果是白天,如果里程小于2,运费是8元,否则是8+(里程-2)*2 如果是夜晚,如果里程小于2,运费是10元,否则是10+(里程-2)*2.4 5.运费加上低速运行时间除以2的整数 6.输出运费 7.输入循环变量,决定是否继续循环
相关知识
为了完成本关任务,你需要掌握:1.如何循环计算,2.如何判断白天或晚上,3.如何计算低速运行费用。
循环计算
判断白天或晚上
计算低速运行费用
在计算里程费用之后,加上低速运行时间除以2的整数 f=f+d//2
测试说明
平台会对你编写的代码进行测试:
示例输入输出:
请输入打车时间(小时:分钟)10:30 请输入里程10 请输入低速行驶时间(分钟)7 车费是27.00元 是否继续(y/n)y 请输入打车时间(小时:分钟)22:30 请输入里程10 请输入低速行驶时间(分钟)2 车费是30.20元 是否继续(y/n)n
参考答案
# 代码开始
jx = "y"
f = 0
while jx == "y" or jx == "Y":
s = input("请输入打车时间(小时:分钟)")
l = float(input("请输入里程"))
d = float(input("请输入低速行驶时间(分钟)"))
h = eval(s[:s.find(":")])
m = eval(s[s.find(":") + 1:])
if h < 5 or (h == 5 and m < 30) or h >= 22:
if l < 2:
f = 10
else:
f = 10 + (l - 2) * 2.4
else:
if l < 2:
f = 8
else:
f = 8 + (l - 2) * 2
print("车费是%0.2f元" %(int(f + d / 2)))
jx = input("是否继续(y/n)")
# 代码结束
>>>第4关:正弦函数的麦克劳林级数
- 任务描述
- 案例分析
- 测试说明
任务描述
本关任务: 编写程序,从键盘输入x的值,根据麦克劳林级数求正弦值,直到最后一项绝对值小于le−7(即10−7)为止 (注:x为弧度值)
案例分析
1.设置循环变量初值 分子 fz=x 分母fm=1 项数i=1求和项s=0 2.当符合循环条件 abs(fz/fm)>=1e-7 3.执行递推关系 s=s+fz/fm fz=fz*(-x)x fm=fm2i(2*i+1) i=i+1
测试说明
平台会对你编写的代码进行测试: 测试输入 输入x3.14 输出 sin(3.14)=0.00
输入1.05 输出 sin(1.05)=0.87
参考答案
import math
x = eval(input("输入x"))
# 代码开始
fz = x
fm = 1
s = 0
n = 1
while abs(fz / fm) >= 1e-7:
s = s + fz / fm
fz = -x * x * fz
fm = fm * (2 * n) * (2 * n + 1)
n = n + 1
print("sin(%.2f)=%.2f" % (x, s))
# 代码结束
>>>第5关:素数判断
- 任务描述
- 案例分析
- 相关知识
- break
- 循环的扩展模式
- 测试说明
任务描述
素数,就是除了1和它自身外,再没有其它因子的自然数。 编写程序,输入一个整数,判断其是否为素数。
案例分析
输入:输入整数x 处理:i从2循环到x-1,若x%i为0,则显示不是素数,退出循环 若循环正常结束,则显示是素数
相关知识
为了完成本关任务,你需要掌握: 1.break 2.循环的扩展模式
break
break常用于循环语句体内,某一个if条件分支的语句中。用来表示在循环过程中,满足某一条件时,结束循环。
循环的扩展模式
for <循环变量> in <遍历结构>: <语句块1> else: <语句块2> 在<语句块1>中,通常有带有if<条件>的break语句。如果在循环过程中,出现符合<条件>的情况,则break退出循环,不会执行else中的语句块2。 如果循环执行完,一直没有符合if后面的<条件>。当for循环执行之后,程序会执行else后面的<语句块2>。
测试说明
平台会对你编写的代码进行测试:
测试输入: 请输入一个整数10 预期输出: 10不是素数
测试输入: 请输入一个整数17 预期输出: 17是素数
参考答案
import math
x = eval(input("请输入一个整数"))
# 代码开始
i = int(math.sqrt(x))
for i in range(2, x):
if x % i == 0:
print("%d不是素数"%x,end="")
break # 可以整除,肯定不是素数,结束循环
else:
print("%d是素数"%x,end="")
# 代码结束
>>>第6关:整数统计
- 任务描述
- 案例分析
- 相关知识点
- 多变量同时赋值
- 永真循环
- continue
- 最大值最小值算法
- 测试说明
任务描述
本关任务: 从键盘输入若干个1-100之间的整数,求这些数的和、个数、平均值、最大值、最小值。 若输入0,则输入结束,显示统计结果。若输入不符合要求的数,则显示输入错误,并不将该数计算在内。
案例分析
1.设置zd变量存放最大值,初值为0。
zx变量存放最小值,初值为100。 s变量存放求和,c变量存放个数。 2.永真循环 输入整数, 若此数为零,退出循环; 若此数为负数或大于100或不是整数,重新输入; 若此数小于zx,则zx赋值为此数 若此数大于zd,则zd赋值为此数 计数器加1。累加器累加此数。 3.退出循环后,输出结果
相关知识点
1.多变量同时赋值 2.永真循环 3.continue 4.最大值、最小值算法
多变量同时赋值
赋值语句可以对多变量同时赋值。 变量1被赋值为表达式1,变量2被赋值为表达式2…… 例如,如果要对a赋值为1,b赋值为0,可以执行a,b=1,0。 也可以直接交换a、b变量的值,执行a,b=b,a后,a为0,b为1。
永真循环
while True: <循环体> 永真循环是指循环条件为True的循环,无条件重复执行循环体。 在循环体里,有分支语句,符合条件则通过break语句退出循环。 在执行循环时,需要能满足退出条件,否则就会成为死循环。
continue
常用于循环语句体内某一个if条件分支的语句中, 满足某一条件时,结束本轮循环,提前进入下一轮循环。 while语句遇到continue时,程序会立刻转到条件表达式,开始下一轮循环; 而在for语句中遇到continue时,程序会立刻更新循环变量,开始下一轮循环。
最大值最小值算法
最大值 在循环之前,将最大值变量设置为最小可能的值。 例如,输入数值是1-100之间,将其设置为1。 在循环过程中,一旦发现输入的数大于该变量的值,就将该变量的值设置为该值。 zd=<初值> while <循环条件>: x=input() if x>zd: zd=x 最小值 在循环之前,将最小值变量设置为最大可能的值。 例如,数值范围是1-100之间,将其设置为100。 在循环过程中,一旦发现输入的数小于该变量的值,就将该变量的值设置为该值。 zx=<初值> while <循环条件>: x=input() if x<zx: zx=x
测试说明
平台会对你编写的代码进行测试:
预期输入
请输入一个整数(1-100)7 请输入一个整数(1-100)9 请输入一个整数(1-100)20 请输入一个整数(1-100)200 输入错误 请输入一个整数(1-100)0
预期输出 有效数3个,和36,平均值12.0,最大值20,最小值7
参考答案
# 代码开始
i = 1
zd = 0 # 最大值
zx = 100 # 最小值
a = 0 # 平均值
s = 0 # 和
c = 0 # 有效个数
# zd, zx, a, s, c = 0, 100, 0, 0, 0 # 多变量同时赋值
while True:
i = int(input("请输入一个整数(1-100)"))
if 100 >= i >= 1:
c += 1
s += i
a = s / c
if i < zx:
zx = i
if i > zd:
zd = i
elif i == 0:
print("有效数%d个,和%d,平均值%.1f,最大值%d,最小值%d" % (c, s, a, zd, zx), end="")
break
else:
print("输入错误")
continue
# 代码结束
>>>第7关:选择题
1、执行下列程序后,输出结果是
x=“hunan university”
for c in x:
if c==“n”:
continue
print(c,end=“”)
A、hu
B、hua uiversity
C、nnn
D、hunan university
2、x=“hunan university”
for c in x:
if c==“n”:
break
print(c,end=“”)
A、hu
B、hua university
C、nnn
D、hunan university
3、程序代码如下所示
s= 0
while True:
k = eval(input(‘请输入0退出:’))
if k==0:
break
elif k<0:
continue
elif k>0:
s=s+k
s=s+1
print(s)
若用户依次输入 3 2 -5 1 0
则程序的输出是
A、1
B、6
C、10
D、9
4、c= 0
while True:
k = eval(input(‘请输入0退出:’))
if k>0:
continue
elif k<0:
c=c+1
elif k==0:
break
c=c+1
print©
依次输入 10 -20 30 -40 -60 0
输出结果是
A、6
B、3
C、-120
D、5
5、while True:
guess = eval(input())
if guess == 100//2:
break
作为输入能够结束程序运行的是
A、50
B、100
C、2
D、“100//2”
6、for count in range(10) 循环执行多少次
A、9
B、10
C、11
D、无限次
7、执行以下程序,输入”93python22”,输出结果是:
w = input(‘请输入数字和字母构成的字符串:’)
for x in w:
if ‘0’<= x <= ‘9’:
continue
else:
w.replace(x,‘’)
print(w)
A、python9322
B、python
C、93python22
D、9322
8、下面代码的输出结果是
sum = 1.0
for num in range(1,4):
sum+=num
print(sum)
A、6
B、7.0
C、1.0
D、7
9、下面代码的输出结果是
for i in range(10):
if i%2==0:
continue
else:
print(i, end=“,”)
A、2,4,6,8,
B、0,2,4,6,8,
C、0,2,4,6,8,10,
D、1,3,5,7,9,
10、以下程序的输出结果是:
x=10
while x:
x-=1
if not x%2:
print(x,end = ‘’)
A、86420
B、975311
C、 97531
D、864200
以上是关于MongoDB实验——数据库基本操作(头歌)的主要内容,如果未能解决你的问题,请参考以下文章