Python是一种高级、通用、解释型的编程语言,具有简洁而清晰的语法,被广泛应用于软件开发、数据科学、人工智能等领域。以下是Python技术的一些主要特点和应用领域:
总体而言,Python是一门功能强大、灵活易用的编程语言,适用于各种规模和类型的项目,从小型脚本到大型应用,都能够得心应手。
1. 输入2000年后的某年某月某日,判断这一天是从2000年1月1日开始算起的第几天?
date=input("请按照2000-01-21格式输入日期:")
year,month,day=int(date[0:4]),int(date[5:7]),int(date[8:])
print(year,month,day)
def DATE(year,month,day):
"计算这一天是从2000年1月1日开始算起的第几天"
sum=0
def Month(month):
nonlocal sum
if month==1:
sum+=0
elif month==2:
sum+=31
elif month==3:
sum+=59
elif month==4:
sum+=90
elif month==5:
sum+=120
elif month==6:
sum+=151
elif month==7:
sum+=181
elif month==8:
sum+=212
elif month==9:
sum+=243
elif month==10:
sum+=273
elif month==11:
sum+=304
elif month==12:
sum+=334
return sum
def Year(year):
nonlocal sum
for i in range(2000,year,1):
if (year%400==0 or (year%4==0 and year%100!=0)):
sum+=366
else: sum+=365 #该年不为闰年,日数为365天
return sum
Month(month)
Year(year)
sum+=(day-1)
print("%s是从2000年1月1日开始算起的第%d天"%(date,sum))
DATE(year,month,day)
2. 公务员面试设计一个程序帮助评委现场去掉一个最低分和一个最高分,再计算面试者平均分。
score=input("请输入评委打分项列表(以空格隔开):")
def avag(list):
"求均为字符串类型列表的平均值"
add,count=0,0
for i in range(len(list)): #字符串元素转化为整型元素
list[i]=int(list[i])
list.sort()
for i in range(1,len(list)-1,1):
add+=list[i]
count+=1
print("评委现场去掉一个最低分和一个最高分,面试者平均分为:%.2f"%(add/count))
avag(score.split(" "))
3. 生成偶数个随机数,将前一半升序排列,后一半按降序排列。
import numpy as np
number=np.random.randint(1, 100) #生成1至100区间内的任意随机数
if number%2!=0: #若随机数不为偶数,则加1
number+=1
number
list=np.random.rand(number)
list
def asc_des(list):
"输入偶数个随机数,将前一半升序排列,后一半按降序排列"
mid=int(len(list)/2)
for i in range(mid):
list1=sorted(list[:mid],reverse=False) #前半部分升序
for i in range(mid,len(list),1):
list2=sorted(list[mid:],reverse=True) #后半部分降序
print("输入偶数个随机数,将前一半升序排列,后一半按降序排列:",list1+list2)
asc_des(list)
4. 统计一个txt的英文文档,里面包含哪些单词,各个单词出现的频率如何。
import numpy as np
import pandas as pd
str=open("./words.txt",mode="r").read()
str
def num(file):
count=1 #count=0代表当前不为字母 count=1代表当前为字母
b=[]
for i in range(len(str)):
if ("a"<=str[i]<="z" or "A"<=str[i]<="Z")and (count==1):
count=1
b.append(str[i])
else:
count=1
b.append(" ")
return b
words=num(str)
words="".join(words)
words
wordslist=words.strip().split() #去掉两边空格,按照空格分割成列表
wordslist2=set(wordslist) #利用集合唯一性去除重复单词
wordslist2=list(wordslist2) #还原成列表
a=[]
for i in range(len(wordslist2)):
a.append(wordslist.count(wordslist2[i]))
a
c=dict(zip(wordslist2,a))
c
k=pd.DataFrame(a,index=wordslist2,columns=["单词次数"])
k
k["单词频数"]=k["单词次数"]/k["单词次数"].sum()
k
1.问题一
2.问题二
3.问题三
4.问题四
Python领域就像一片未被勘探的信息大海,引领你勇敢踏入Python数据科学的神秘领域。这是一场独特的学习冒险,从基本概念到算法实现,逐步揭示更深层次的模式分析、匹配算法和智能模式识别的奥秘。