基于new bing的注释
# 定义函数,参数为整数n,用于检查n的每一位是否不重复
def isdiff(n):
# 初始化列表li,长度为10,用于记录数字出现次数
li = [0] * 10
# 将n转化为字符串类型
s = str(n)
# 初始化标志位flag为True,表示n的每一位都不相同
flag = True
# 遍历字符串s中的每一位数字
for i in s:
# 将数字字符转化为整型
k = int(i)
# 对应数字在li中的计数加1
li[k] += 1
# 如果该数字出现的次数大于1,则说明n的某一位数字出现了重复
if li[k] > 1:
# 修改标志位flag,并退出循环
flag = False
break
# 返回标志位flag,表示整数n的每一位数字是否都不相同
return flag
# 定义函数,参数为整数n,用于检查n的每一位是否不重复
def isdiff2(n):
# 将n转化为字符串类型
s = str(n)
# 将字符串s转化为集合类型m
m = set(s)
# 如果m的长度等于s的长度,则说明n的每一位数字都不相同
# 否则,说明n的某一位数字出现了重复
return len(m) == len(s)
# 从用户处读取闭区间下界low和上界high的值
low = int(input("low:"))
high = int(input("high:"))
# 输出表头
print("x\tx*x")
# 统计满足条件的整数的数量,初始化为0
k = 0
# 遍历闭区间[low, high]内的每个整数n
for n in range(low, high+1):
# 如果n符合要求,则输出n和n的平方
if isdiff(n) and isdiff2(n):
print(f"{n}\t{n * n}")
# 满足条件的整数数量加1
k += 1
# 输出满足条件的整数总数
print("总数为:", k)
点击标题能够进入到最终的详情页,因此我们只需要获得每个标题的a链接并多次翻页就可以喽!
content = tree2.xpath('//*[@id="ctl00"]/table/tbody/tr[2]/td/table/tbody//tr/td[2]/a/@href')
next_src = tree2.xpath('//*[@id="ctl00"]/table/tbody/tr[3]/td/table/tbody/tr/td/div/a[last()]/@href')[0]
next_url = "https://kns.cnki.net/kns/brief/brief.aspx"+next_src
tb.get(next_url) # 跳转到下一页
page_text = tb.page_source # 获取下一页的页面内容
抱歉,参考资料中没有提供该程序的截图和题目信息,请提供更具体的参考资料以便回答问题。