仿照图形化软件中的映射,编写一段映射类。运行程序后,输入:5,映射后:1;输入:200,映射后:49。程序①处应补全的语句是?( )
class Ying():
def __init__(self,a,b,c,d,e):
self.a=a
self.b=b
self.c=c
self.d=d
self.e=e
def ys(self):
return (self.a*(self.e-self.d))/(self.c-self.b)
a=float(input('输入值:'))
b=Ying(a,0,1023,0,255)
print("映射前:%d 映射后:%d"%(a, ① ))
a.ys()
b.ys()
b
b.self()
Python语言关于类的定义错误的是?( )
类名的每个单词的首字母都要大写,且不使用下划线分隔单词
类命名尽量简洁且有意义
类的定义必须在引用之前
运行以下Python程序后,将打印输入两个整数的取余运算结果,划线处的代码为?( )
class Mi():
def __init__(self,a,b):
self.a=a
self.b=b
def yu(self):
return self.a % self.b
a=int(input('输入第一个数:'))
b=int(input('输入第二个数:'))
c=
print(c.yu())
Mi(a%b)
a%b
self.a % self.b
Mi(a,b)
从json文件中读取数据,并使用json模块中的load方法将其转换为Python的字典对象。下面哪个选项是正确的代码?( )
d = json.load(open('data.json'))
d = json.loads('data.json')
d = open('data.json').load(json)
d = open('data.json').loads(json)
在Python中,使用json模块将Python字典转换为JSON字符串的方法是?( )
json.load()
json.loads()
json.dump()
json.dumps()
在Python中,以下代码的功能是?( )
with open('data.csv', 'r') as f:
reader = csv.DictReader(f)
for row in reader:
print(row['name'])
以字典形式读取CSV,打印name列
将CSV转为JSON格式输出
统计name列的出现次数
修改CSV文件的name列
在Python中,关于一维数据的CSV文件存储,以下说法正确的是?( )
CSV文件只能存储数值型数据
写入CSV时,一维列表应转换为二维嵌套列表
csv.writerow()方法可以直接写入一维列表
读取CSV文件时,必须指定delimiter=';'
在Python中,以下代码的输出是? ( )
import numpy as np
x = np.arange(10, 20, 3)
print(x[-1])
10
16
19
报错
在tkinter中,用于创建按钮的类是?( )
Button
Label
Entry
Frame
在tkinter中用于处理按钮点击事件的参数是?( )
action
click
command
event
在tkinter中执行以下代码后,窗口将显示什么?( )
import tkinter as tk
root = tk.Tk()
tk.Label(root, text="Hello").pack(side="left")
tk.Label(root, text="World").pack()
root.mainloop()
Hello在左,World在右
Hello在上,World在下
Hello在左,World自上居中
Hello在左,World在下方
在tkinter中要使Button点击时执行函数show(),正确写法是?( )
tk.Button(root, command=show()).pack()
tk.Button(root, command=show).pack()
tk.Button(root, bind=show).pack()
tk.Button(root, onclick=show).pack()
如果你要用numpy快速创建一个10个元素、值全为0的一维数组,不正确的方法是?( )
numpy.zeros(10)
numpy.zeros([10])
numpy.zeros((10,))
numpy.zeros([10.])
用matplotlib画图时,显示折线图常用的函数是?( )
plt.show()
plt.plot()
plt.scatter()
plt.hist()
下列代码运行后,图表的标题会显示什么?( )
import matplotlib.pyplot as plt
plt.rcParams["font.sans-serif"] = "SimHei"
plt.plot([1, 2, 3], [4, 5, 6])
plt.title("成绩走势")
plt.show()
不显示标题
"成绩走势"
"matplotlib图"
程序出错
使用numpy时,以下哪种操作可以用来计算数组的平均值?( )
numpy.sum()
numpy.mean()
numpy.max()
numpy.size()
你有一个大文件,需要从文件的第 10 个字节处开始读取数据。应该使用以下哪个方法?( )
f.seek(10)
f.tell(10)
f.read(10)
f.write(10)
你有一个日志文件,需要不断将新的日志信息添加到文件末尾。以下哪种方式可以完成该功能?( )
执行以下代码后,file.txt 文件的内容是?( )
with open('file.txt', 'w') as f:
f.write('First line\n')
with open('file.txt', 'a') as f:
f.write('Second line\n')
with open('file.txt', 'r+') as f:
f.seek(0)
f.write('Replaced first line\n')
First line
Second line
Replaced first line
Second line
First line
Replaced first line
Replaced first line
在处理日志文件时,需要把日志的行顺序反转,方便查看最新的日志记录(即文件里的内容按行倒序)。下面哪个代码能正确实现?( )
某小型书店需要管理其图书库存,决定使用SQLite数据库来存储图书信息。在创建数据库和图书表的过程中,以下哪个步骤是正确的?( )
使用connect('library.db')创建数据库连接后,直接执行INSERT语句插入数据
创建表后,必须使用commit()方法提交事务,否则数据不会保存
关闭数据库连接时,先关闭游标,再关闭连接
使用CREATE TABLE语句时,必须指定主键
物流轨迹跟踪系统中若需获取前3条记录,以下哪种方式最高效?( )
conn = sqlite3.connect('logistics.db')
cursor = conn.cursor()
cursor.execute('''
SELECT track_id, location, timestamp
FROM tracking
WHERE package_id = ?
ORDER BY timestamp DESC''', ('PKG12345',))
# 获取最新轨迹
latest_record = cursor.fetchone()
[cursor.fetchone() for _ in range(3)]
cursor.fetchmany(3)
cursor.fetchall()[:3]
循环调用fetchone()三次
用Python语言对SQLite数据库进行编程,实现打开和关闭stu.db数据库文件。下列命令语句,执行先后顺序正确选项是?( )
①conn = sqlite3.connect("test.db")
②cur = conn.cursor( )
③import sqlite3
④conn.close( )
⑤cur.close( )
①②③④⑤
②①③⑤④
③①②⑤④
③①②④⑤
在图书馆管理系统中,有一个列表 new_books = [('Book 1', 'Author 1'), ('Book 2', 'Author 2')],需要将这些书籍信息插入到 books 表中,以下代码正确的是?( )
Python语言关于类的说法错误的是?( )
函数可以定义到类中,称为方法。功能不变,使用格式不同
定义类后,必须定义一个类的实例才能使用类的方法
导入类必须重命名后才能使用,如:import turtle as t
可以导入单个类,也可以导入多个类。 如:导入单个:from car import Car 导入多个: from module_name import Class_a, Class_b
在Python语言中,先定义类,再使用类创建出具体的对象:即实例。不同的实例可以带不同的参数,但它们使用相同的方法。( )
对
错
在Python语言中,针对同一个对象(实例)的相同操作,可以定义类和类的方法,以便重复调用。( )
对
错
在Python中,使用json.load()读取JSON文件时,文件对象必须以二进制模式打开(如'rb')。( )
对
错
在Python中,json.loads()可以将JSON字符串转为Python字典。( )
对
错
tkinter中主窗口必须手动设置geometry()才能显示。( )
对
错
numpy数组比Python普通列表占用内存更高,速度更慢。( )
对
错
numpy只能处理一维数据,不能处理多维矩阵。( )
对
错
Python 中的 with 语句在处理文件操作时,会自动关闭文件,即使在执行过程中发生异常也能保证文件被正确关闭。( )
对
错
在 Python 中,使用open()函数打开文件进行读取时,文件路径必须是绝对路径。( )
对
错
一个学生成绩管理系统需要从SQLite数据库中查询学生信息。在执行查询操作时,fetchmany(size=2)会返回结果中的前两行。( )
对
错
管理电话号码
编写一个使用SQLite管理电话号码的程序,功能有:显示所有电话号码、添加、删除和退出,请补全程序。
(本题无需运行通过,写入代码即可)
import sqlite3
def init_db():
conn = sqlite3.connect('phonebook.db')
cursor = conn.cursor()
cursor.execute("DROP TABLE IF EXISTS contacts")
cursor.execute('''CREATE TABLE contacts (name TEXT NOT NULL,phone TEXT PRIMARY KEY)''')
conn.commit()
return conn
def show_all_contacts(conn):
cursor = conn.cursor()
cursor.execute("SELECT name, phone FROM contacts ORDER BY name")
contacts = cursor. ①
if not contacts:
print("电话簿为空")
return
for name, phone in contacts:
print(f"{name}: {phone}")
def add_contact(conn):
name = input("请输入姓名: ").strip()
phone = input("请输入电话号码: ").strip()
if not name or not phone:
print("错误: 姓名和电话都不能为空")
return
try:
cursor = conn.cursor()
cursor.execute("INSERT INTO contacts (name, phone) VALUES (?, ?)", ( ② , ③ ))
conn.commit()
print(f"成功添加联系人: {name} - {phone}")
except sqlite3.IntegrityError:
print("错误: 该电话号码已存在")
def delete_contact(conn):
phone = input("请输入要删除的电话号码: ").strip()
if not phone:
print("错误: 请输入有效的电话号码")
return
cursor = conn.cursor()
cursor.execute("SELECT name FROM contacts WHERE phone=?", (phone,))
result = cursor. ④
if not result:
print("错误: 未找到该电话号码")
return
confirm = input(f"确定要删除 {result[0]}({phone}) 吗? (y/n): ").lower()
if confirm == 'y':
cursor.execute("DELETE FROM contacts WHERE phone=?", (phone,))
conn.commit()
print("联系人已删除")
else:
print("取消删除")
# 主程序
def main():
conn = init_db()
while True:
print("----------------")
show_all_contacts(conn)
print("\n请选择操作:")
print("1. 添加联系人")
print("2. 删除联系人")
print("0. 退出程序")
choice = input("请输入选项(0-2): ").strip()
if choice == "1":
add_contact(conn)
elif choice == "2":
delete_contact(conn)
elif choice == "0":
print("\n感谢使用电话簿管理系统,再见!")
conn.close()
break
else:
print("无效输入,请重新选择!")
if __name__ == "__main__":
main()
工资系统
某学校需要开发一个教师工资计算系统,该系统需要根据教师的职称、基本工资和课时工资自动计算每位教师的月工资。教师的工资由两部分组成:
结构工资 = 基本工资 × 职称系数
总工资 = 结构工资 + 课时工资
学校制定了不同职称对应的配置标准:
对于未列出的职称,使用默认值:基本工资5000,职称系数1.0。
输入输出示例
输入数据格式为元组:(姓名, 职称, 课时工资)
test_cases = [ ("张老师", "一级教师", 1200), ("李老师", "副高级教师", 1500),("王老师", "特级教师", 2000) ]
预期输出:
张老师(一级教师)总工资:7800.0
李老师(副高级教师)总工资:11100.0
王老师(特级教师)总工资:7000.0
相关Python程序如下,请补全代码完成功能实现。
TITLE_CONFIG = {
"二级教师": {"coeff": 1.0, "base": 5000},
"一级教师": {"coeff": 1.1, "base": 6000},
"副高级教师": {"coeff": 1.2, "base": 8000}
}
class Teacher:
def __init__(self, name, title, hourly_wage):
self.name = name
self.title = title
self.hourly_wage = hourly_wage
self.config = TITLE_CONFIG.get(title, {"coeff": 1.0, "base": 5000})
def calculate_structural_salary(self):
return self.config["base"] * ①
def total_salary(self):
return self.calculate_structural_salary() + ②
test_cases = [("张老师", "一级教师", 1200), ("李老师", "副高级教师", 1500), ("王老师", "特级教师", 2000)]
for case in test_cases:
③ = Teacher(*case)
print(f"{teacher.name}({teacher.title})总工资:{ ④ :.1f}")
IP地址记录
小明的IP地址记录在文件ip_list.txt中,但其中有些IP属于内网(局域网IP段如192.开头),小明想要:
(1)读取所有IP地址
(2)删除每行末尾换行符
(3)筛选出不是以192.开头的IP地址
(4)将这些IP地址逆序排列后保存到新文件ip_result.txt
(5)并在屏幕上显示每一条被保存的IP
请根据下面代码框架补充完整(共4个填空)。
# 读取ip_list.txt
with open('/data/ip_list.txt', 'r') as f:
ip_list = ①
# 处理IP列表
clean_list = []
for ip in ip_list:
ip = ip.strip('\n')
if not ip.startswith( ② ):
clean_list.append(ip)
# 逆序排列
clean_list.reverse()
# 保存到新文件并输出
with open('ip_result.txt', 'w') as f:
for ip in clean_list:
f.write(ip + "\n")
print( ③ )
a= ④ ("按p退出程序")
if a=="p":
exit()