威尼斯人线上娱乐

Python中国和扶桑期时间案例演示,从零学python种类之数据处理编制程序实例

4 5月 , 2019  

案例:策画拾一人姓名,然后为那12个人自由生成寿辰【都是90后】

Python中国和日本期时间案例演示,python案例

案例:计划十二人姓名,然后为那11位随便生成寿辰【都是90后】

一、总计出那一人是夏季【十二月-一月】出生的。

贰、最大的比非常小的很多少天

三、何人的衡阳最早,什么人的上饶最晚

备注:春季【3-5】夏季【6-8】秋季【9-11】冬季【12-2】

 

演示:

from datetime import date, timedelta

from random import randint

 

 

def build_birthday(list_person_name:list):

   # 初阶化存款和储蓄“姓名:生日”字典

*    *name_birthday ={}.fromkeys(list_person_name)

   # 生成破壳日

*    *for key in name_birthday:

       temp_year = randint(1990, 1999)

       temp_month = randint(1, 12)

       temp_day = randint(1, 30)

       name_birthday[key] = date(temp_year, temp_month, temp_day)

   # 返回

*    *return name_birthday

 

def person_birthday_summer(name_birthday:dict):

   # 用于存款和储蓄夏日诞生的key

*    *list_person = []

   for key in name_birthday:

       if name_birthday[key].month
>= 6 and name_birthday[key].month <= 8:

            list_person.append(key)

   # 返回

*    *return list_person

 

 

def get_person_year_max(name_birthday:dict):

   # 在字典中领到出寿辰

*    *person_birth = list(name_birthday.values())

   # 获取最大的八字

*    *max_birthday = sorted(person_birth)[len(person_birth)-1]

   # 遍历

*    *for key in name_birthday:

       if name_birthday[key] == max_birthday:

            return key

 

 

def get_person_year_min(name_birthday:dict):

   # 在字典中提抽取生日

*    *person_birth = list(name_birthday.values())

   # 获取最小的交州

*    *min_birthday = sorted(person_birth)[0]

   # 遍历

*    *for key in name_birthday:

       if name_birthday[key] == min_birthday:

            return key

 

def get_person_days(name_birthday:dict):

   # 在字典中领到出生日

*    *person_birth = list(name_birthday.values())

   # 获取最大的生日

*    *min_birthday = sorted(person_birth)[0]

   max_birthday = sorted(person_birth)[len(person_birth)- 1]

   # 重返天数

*    *return (max_birthday-min_birthday).days

 

def get_person_early_birthday(name_birthday:dict):

   for key in name_birthday:

       name_birthday[key] = name_birthday[key].replace(year=1990)

 

   person_birth = list(name_birthday.values())

   return(sorted(person_birth)[0])

 

def get_person_later_birthday(name_birthday:dict):

   for key in name_birthday:

       name_birthday[key] = name_birthday[key].replace(year=1990)

 

   person_birth = list(name_birthday.values())

   return(sorted(person_birth)[len(person_birth)-1])

 

 

if __name__ == “__main__”:

   list_name =
[“赵一”“杨二”“张三”“李四”“王五”“赵六”“马七”“郑八”“刘九”,“胡十”]

# 为list_name中具有的学生生成生日

*    *name_birthday = build_birthday(list_name)

   print(name_birthday)

   # 调用作用模块

*    *birthday_Python中国和扶桑期时间案例演示,从零学python种类之数据处理编制程序实例。summer_list =person_birthday_summer(name_birthday)

   if len(birthday_summer_list) == 0:

       print(“未有人的八字是在朱律: “)

   else:

       print(“出生之日为夏天的有:”,
birthday_summer_list)  # 需求一

*    # 需求二*

*    *print(“破壳日最大的:”, get_person_year_max(name_birthday))

   print(“破壳日最小的:”, get_person_year_min(name_birthday))

   print(“最大比最小的天数:”, get_person_days(name_birthday))

   # 需求三

*    *date_early =get_person_early_birthday(name_birthday)

   print(“寿辰最大的是:%d月%d日”%(date_early.month,date_early.day))

 

   date_later = get_person_later_birthday(name_birthday)

   print(“破壳日最小的是:%d月%d日” % (date_later.month,
date_early.day))

 

实践结果:

C:\python\python.exeC:/python/demo/file3.py

{‘赵一’:datetime.date(1992, 12, 30), ‘杨二’: datetime.date(1995,6, 23),
‘张三’: datetime.date(1990, 6, 21), ‘李四’:datetime.date(1991, 9, 29),
‘王五’:datetime.date(1996, 2, 26), ‘赵六’:datetime.date(1995, 9, 18),
‘马七’:datetime.date(1996, 7, 4), ‘郑八’:datetime.date(1990, 3, 5),
‘刘九’:datetime.date(1992, 3, 3), ‘胡十’:datetime.date(1992, 11, 6)}

西宁为夏天的有: [‘杨二’,’张三’,’马七’]

济宁最大的: 马七

江门最小的: 郑8

最大比最小的造化: 2313

三亚最大的是:1月231日

西宁最小的是:一月十四日

 

Process finished with exit code 0

案例:打算11人姓名,然后为那11位随便生成生日【都以90后】
壹、计算出那么些人是夏季【八月-八月】…

1、字符串

1.1、怎样在Python中使用字符串

a、使用单引号(‘)

用单引号括起来表示字符串,比如:

str=’this is string’;

print str;

 

b、使用双引号(“)

双引号中的字符串与单引号中的字符串用法完全一样,举个例子:

str=”this is string”;

print str;

 

c、使用叁引号(”’)

行使3引号,表示多行的字符串,能够在3引号中专断的行使单引号和双引号,比如:

str=”’this is string

this is pythod string

this is string”’

print str;

 

在上一节从零学python连串之数据管理编制程序实例(一)的功底上多少发生了更改,文件中除去学生的成绩外,新扩展了学生姓名和出生年月的消息,因而将要成产生:分别依据姓名输出各样学生的无重复的前四个最棒成绩和出生年月

一、计算出这些人是夏季【三月-2月】出生的。

2、布尔类型

bool=False;

print bool;

bool=True;

print bool;

 

 

数码计划:分别创造两个公文文件

贰、最大的比极小的许多少天

三、数字类型

叁.一、基本使用

整数

int=20;

print int;

 

浮点数

float=2.3;

print float;

 

三.贰、删除数字对象引用,比方:

a=1;

b=2;

c=3;

del a;

del b, c;

#print a; #删除a变量后,再调用a变量会报错

 

3.三、数字类型调换

int(x [,base]) 将x转换为一个整数

float(x ) 将x转换到一个浮点数

complex(real [,imag]) 创建一个复数

str(x) 将对象x转换为字符串

repr(x) 将对象x转换为表达式字符串

eval(str) 用来计算在字符串中的有效Python表达式,并返回一个对象

tuple(s) 将序列s转换为一个元组

list(s) 将序列s转换为一个列表

chr(x) 将一个整数转换为一个字符

unichr(x) 将一个整数转换为Unicode字符

ord(x) 将一个字符转换为它的整数值

hex(x) 将一个整数转换为一个十六进制字符串

oct(x) 将一个整数转换为一个八进制字符串

 

3.四、数学函数

abs(x)    返回数字的绝对值,如abs(-10) 返回 10

ceil(x)    返回数字的上入整数,如math.ceil(4.1) 返回 5

cmp(x, y) 如果 x < y 返回 -1, 如果 x == y 返回 0, 如果 x > y 返回 1

exp(x)    返回e的x次幂(ex),如math.exp(1) 返回2.718281828459045

fabs(x)    返回数字的绝对值,如math.fabs(-10) 返回10.0

floor(x) 返回数字的下舍整数,如math.floor(4.9)返回 4

log(x)    如math.log(math.e)返回1.0,math.log(100,10)返回2.0

log10(x) 返回以10为基数的x的对数,如math.log10(100)返回 2.0

max(x1, x2,…)    返回给定参数的最大值,参数可以为序列。

min(x1, x2,…)    返回给定参数的最小值,参数可以为序列。

modf(x)    返回x的整数部分与小数部分,两部分的数值符号与x相同,整数部分以浮点型表示。

pow(x, y)     x**y 运算后的值。X的y次方

round(x [,n]) 返回浮点数x的四舍五入值,如给出n值,则代表舍入到小数点后的位数。

sqrt(x)    返回数字x的平方根,数字可以为负数,返回类型为复数,如math.sqrt(4)返回 2+0j

 

 

 

              james2.txt     James
Lee,2002-3-14,2-34,3:21,2.34,2.45,3.01,2:01,2:01,3:10,2-22

三、什么人的八字最早,什么人的出生之日最晚

4、列表

四.一、起首化列表,举个例子:
list=[‘physics’, ‘chemistry’, 1997, 2000];
nums=[1, 3, 5, 7, 8, 13, 20];

四.二、访问列表中的值,举例:

”’nums[0]: 1”’

print "nums[0]:", nums[0]

”’nums[2:5]: [5, 7, 8] 从下标为2的元素切割到下标为5的元素,但不包含下标为5的元素”’

print "nums[2:5]:", nums[2:5]

”’nums[1:]: [3, 5, 7, 8, 13, 20] 从下标为1切割到最后一个元素”’

print "nums[1:]:", nums[1:]

”’nums[:-3]: [1, 3, 5, 7] 从最开始的元素一直切割到倒数第3个元素,但不包含倒数第三个元素”’

print "nums[:-3]:", nums[:-3]

”’nums[:]: [1, 3, 5, 7, 8, 13, 20] 返回所有元素”’

print "nums[:]:", nums[:]

 

四.三、更新列表,比方:

nums[0]=”ljq”;

print nums[0];

4.四、删除列表成分

del nums[0];”’nums[:]: [3, 5, 7, 8, 13, 20]”’

print “nums[:]:”, nums[:];

四.5、列表脚本操作符
列表对+和*的操作符与字符串相似。+号用于组合列表,*号用于重复列表,举个例子:

print len([1, 2, 3]); #3

print [1, 2, 3] + [4, 5, 6]; #[1, 2, 3, 4, 5, 6]

print [‘Hi!’] * 4; #[‘Hi!’, ‘Hi!’, ‘Hi!’, ‘Hi!’]

print 3 in [1, 2, 3] #Truefor x in [1, 2, 3]: print x, #1 2 3

4.陆、列表截取

L=[‘spam’, ‘Spam’, ‘SPAM!’];

print L[2]; #’SPAM!’

print L[-2]; #’Spam’

print L[1:]; #[‘Spam’, ‘SPAM!’]

 

 

四.七、列表函数&方法

list.append(obj) 在列表末尾增多新的目标

list.count(obj) 总结某些成分在列表中出现的次数

list.extend(seq)
在列表末尾一遍性追加另三个连串中的八个值(用新列表扩展原来的列表)

list.index(obj) 从列表中寻找某些值第贰个匹配项的目录地点,索引从0起始

list.insert(index, obj) 将对象插入列表

list.pop() 移除列表中的2个因素(暗许最后贰个要素),并且重回该因素的值

list.remove(obj) 移除列表中有个别值的率先个相称项

list.reverse() 反向列表兰月素,倒转

list.sort([func]) 对原列表实行排序

 

              julie2.txt        Julie
Jones,2002-8-17,2.59,2.11,2:11,2:23,3-10,2-23,3:10,3.21,3-21

备注:春季【3-5】夏季【6-8】秋季【9-11】冬季【12-2】

5、元组(tuple)

Python的元组与列表类似,分化之处在于元组的因素不能够改改;元组使用小括号(),列表使用方括号[];元组创制很简短,只供给在括号中添美金素,并应用逗号(,)隔离就可以,比方:

tup1 = (‘physics’, ‘chemistry’, 1997, 2000);

tup2 = (1, 2, 3, 4, 5 );

tup3 = (“a”, “b”, “c”, “d”);

 

创建空元组,比方:tup = ();

元组中唯有多个成分时,要求在要素前边加多逗号,比方:tup一 = (50,);

元组与字符串类似,下标索引从0开端,能够实行截取,组合等。

5.壹、访问元组

tup1 = (‘physics’, ‘chemistry’, 1997, 2000);

#tup1[0]: physics

print “tup1[0]: “, tup1[0]

#tup1[1:5]: (‘chemistry’, 1997)

print “tup1[1:5]: “, tup1[1:3]

5.2、修改元组
元组中的成分值是不容许修改的,但我们得以对元组实行两次三番组合,比如:
tup1 = (12, 34.56);
tup2 = (‘abc’, ‘xyz’);

# 以下修改元组成分操作是私下的。
# tup1[0] = 100;

# 创制三个新的元组

tup3 = tup1 + tup2;

print tup3; #(12, 34.56, ‘abc’, ‘xyz’)

5.3、删除元组
元组中的成分值是不允许删除的,能够行使del语句来删除全体元组,举个例子:

tup = (‘physics’, ‘chemistry’, 1997, 2000);

print tup;

del tup;

 

 

五.4、元组运算符
与字符串一样,元组之间能够利用+号和*号举行演算。那就象征她们得以构成和复制,运算后会生成一个新的元组。

 

5.5、元组索引&截取

L = (‘spam’, ‘Spam’, ‘SPAM!’);

print L[2]; #’SPAM!’

print L[-2]; #’Spam’

print L[1:]; #[‘Spam’, ‘SPAM!’]

 

 

五.6、元组内置函数

cmp(tuple1, tuple二) 比较多个元组成分。

len(tuple) 计算元组成分个数。

max(tuple) 重回元组桐月素最大值。

min(tuple) 重返元组7月素最小值。

(seq) 将列表转变为元组。

 

 

              mikey2.txt      Mikey
McManus,2002-2-24,2:22,3.01,3:01,3.02,3:02,3.02,3:22,2.49,2:38

 

6、字典

6.一、字典简单介绍
字典(dictionary)是除列表之外python中最灵敏的停放数据结构类型。列表是平稳的对象结合,字典是冬季的目的集结。两者之间的界别在于:字典个中的成分是通过键来存取的,而不是经过偏转移存入取。

字典由键和呼应的值组成。字典也被称作关联数组或哈希表。基本语法如下:

dict = {‘Alice’: ‘2341’, ‘Beth’: ‘9102’, ‘Cecil’: ‘3258’};

也可那样创建字典:

dict1 = { ‘abc’: 456 };

dict2 = { ‘abc’: 123, 98.6: 37 };

各种键与值必须用冒号隔断(:),每对用逗号分割,全部放在花括号中({})。键必须天下无双,但值则无需;值能够取任何数据类型。

 

 

陆.二、访问字典里的值

#!/usr/bin/python

dict = {‘name’: ‘Zara’, ‘age’: 7, ‘class’: ‘First’};

print “dict[‘name’]: “, dict[‘name’];

print “dict[‘age’]: “, dict[‘age’];

 

 

陆.三、修改字典
向字典增添新内容的章程是充实新的键/值对,修改或删除已有键/值对如下实例:

#!/usr/bin/python

dict = {‘name’: ‘Zara’, ‘age’: 7, ‘class’: ‘First’};

dict[“age”]=27; #修改已有键的值

dict[“school”]=”wutong”; #充实新的键/值对

print “dict[‘age’]: “, dict[‘age’];

print “dict[‘school’]: “, dict[‘school’];

 

 

六.四、删除字典
del dict[‘name’]; # 删除键是’name’的条规
dict.clear(); # 清空词典全数条条框框
del dict ; # 删除词典
例如:

#!/usr/bin/python

dict = {‘name’: ‘Zara’, ‘age’: 7, ‘class’: ‘First’};

del dict[‘name’];

#dict {‘age’: 7, ‘class’: ‘First’}

print “dict”, dict;

在意:字典不存在,del会引发三个不行

 

 

六.五、字典内置函数&方法

cmp(dict一, dict二) 相比多少个字典成分。

len(dict) 计算字典成分个数,即键的总量。

str(dict) 输出字典可打印的字符串表示。

type(variable) 再次回到输入的变量类型,假如变量是字典就回去字典类型。
clear() 删除字典内具有因素

copy() 再次回到1个字典的深拷贝(在python中,函数的参数字传送递是:引用传递)

fromkeys(seq)
创设三个新字典,以体系seq桐月素做字典的键,val为字典全体键对应的开始值

get(key, None) 重返钦定键的值,若是值不在字典中回到default值

has_key(key) 假若键在字典dict里重回true,不然重返false

items() 以列表再次回到可遍历的(键, 值) 元组数组

keys() 以列表再次来到四个字典全部的键

setdefault(key, default=None) 和get()类似,
但假如键不已经存在于字典中,将会增加键并将值设为default

dict一.update(dict二) 把字典dict二的键/值周旋异到dict一里

values() 以列表再次来到字典中的全体值

 

              sarah2.txt      Sarah
Sweeney,2002-6-17,2:58,2.58,2:39,2-25,2-55,2:54,2.18,2:55,2:55

演示:

柒、日期和岁月

七.一、获取当前岁月,例如:
import  time, datetime;

#近年来时间:

localtime = time.localtime(time.time())

print “Local current time :”, localtime

## 结构化时间
time.struct_time(tm_year=2014, tm_mon=3, tm_mday=21, tm_hour=15,
tm_min=13, tm_sec=56, tm_wday=4, tm_yday=80, tm_isdst=0)
说明:time.struct_time(tm_year=2014, tm_mon=3, tm_mday=21,
tm_hour=15, tm_min=13, tm_sec=56, tm_wday=4, tm_yday=80,
tm_isdst=0)属于struct_time元组,struct_time元组具有如下属性:

 

柒.2、获取格式化的时日
能够依照须要选择种种格式,不过最简便的收获可读的年华情势的函数是asctime():
一、日期调换为字符串

首选:print time.strftime(‘%Y-%m-%d %H:%M:%S’);

其次:print datetime.datetime.strftime(datetime.datetime.now(),
‘%Y-%m-%d %H:%M:%S’)

最后:print str(datetime.datetime.now())[:19]

 

二、字符串调换为日期

expire_time = “2013-05-21 09:50:35”

d = datetime.datetime.strptime(expire_time,”%Y-%m-%d %H:%M:%S”)

print d;

 

⑦.三、获取日期差

 

## 定义时差步长

oneday = datetime.timedelta(days=1)

#今天,2014-03-21

today = datetime.date.today()

#昨天,2014-03-20

yesterday = datetime.date.today() – oneday

#明天,2014-03-22

tomorrow = datetime.date.today() + oneday

#获得明日零点的时光,201④-03-21 00:00:00

today_zero_time = datetime.datetime.strftime(today, ‘%Y-%m-%d
%H:%M:%S’)

 

#0:00:00.001000

print datetime.timedelta(milliseconds=1), #1毫秒

#0:00:01

print datetime.timedelta(seconds=1), #1秒

#0:01:00

print datetime.timedelta(minutes=1), #1分钟

#1:00:00

print datetime.timedelta(hours=1), #1小时

#1 day, 0:00:00

print datetime.timedelta(days=1), #1天

#7 days, 0:00:00

print datetime.timedelta(weeks=1)

 

7.四、获取时间差

 

#1 day, 0:00:00

oneday = datetime.timedelta(days=1)

#今天,2014-03-21 16:07:23.943000

today_time = datetime.datetime.now()

#昨天,2014-03-20 16:07:23.943000

yesterday_time = datetime.datetime.now() – oneday

#明天,2014-03-22 16:07:23.943000

tomorrow_time = datetime.datetime.now() + oneday

注意时间是浮点数,带飞秒。

 

那正是说要取稳妥前光阴,要求格式化一下:

print datetime.datetime.strftime(today_time, ‘%Y-%m-%d %H:%M:%S’)

威尼斯人线上娱乐 ,print datetime.datetime.strftime(yesterday_time, ‘%Y-%m-%d %H:%M:%S’)

print datetime.datetime.strftime(tomorrow_time, ‘%Y-%m-%d %H:%M:%S’)

 

七.5、获取上一个月最终1天

last_month_last_day =
datetime.date(datetime.date.today().year,datetime.date.today().month,1)-datetime.timedelta(1)

 

7.陆、字符串日期格式化为秒数,重临浮点类型:

expire_time = “2013-05-21 09:50:35”

d = datetime.datetime.strptime(expire_time,”%Y-%m-%d %H:%M:%S”)

time_sec_float = time.mktime(d.timetuple())

print time_sec_float

 

7.7、日期格式化为秒数,重临浮点类型:

d = datetime.date.today()

time_sec_float = time.mktime(d.timetuple())

print time_sec_float

 

柒.八、秒数转字符串

time_sec = time.time()

print time.strftime(“%Y-%m-%d %H:%M:%S”, time.localtime(time_sec))

 

 在上一节基础上,修改部分代码,将新供给兑现如下:

from datetime import date, timedelta

复制代码 代码如下:

from random import randint

import os
print(os.getcwd())
os.chdir(‘C:\Python33\HeadFirstPython\hfpy_code\chapter6’) 
#将专门的学业空间修改为文件所在的目录

 

#概念函数get_filedata从文件中取值
def get_filedata(filename):
    try:
        with open(filename)  as f:        #with语句张开和机关关闭文件
            data=f.readline()                 #从文件中逐行读取字符
            data_list=data.strip().split(‘,’)  
#将字符间的空格清除后,用逗号分隔字符
            return({
                    “name” : data_list.pop(0),
                    “date_of_birth” : data_list.pop(0),
                    “times” : str(sorted(set([modify_time_format(s)
for s in data_list]))[0:3])
                    })                               
#应用字典将波及的真名,出生年月,时间键和值进行仓库储存并回到
    except IOError as ioerr:
        print (‘File Error’ + str(ioerr))     #那多少个管理,打字与印刷错误
        return (None)

 

#概念函数modify_time_format将具有文件中的时分表明方式统一为“分.秒”
def modify_time_format(time_string):
    if “-” in time_string:
        splitter=”-“
    elif “:” in time_string:
        splitter=”:”
    else:
        splitter=”.”
    (mins, secs)=time_string.split(splitter)
#用分隔符splitter分隔字符后分别存入mins和secs
    return (mins+ ‘.’ +secs)

def build_birthday(list_person_name:list):

#概念函数get_prev_three重临文件中排行前叁的不重复的时日战绩
def get_prev_three(filename):
    new_list=[modify_time_format(each_t) for each_t in
get_filedata(filename)]  
#采取列表推导将合并时分表达情势后的记录生成新的列表
   
delete_repetition=set(new_list)                                                                    
#动用集结set函数删除新列表中重复项,并生成新的成团
   
in_order=sorted(delete_repetition)                                                              
#应用复制排序sorted函数对无重复性的新集结举办排序
    return (in_order[0:3])     

   # 初叶化存款和储蓄“姓名:寿辰”字典

#输出james的排行前3的不另行成绩和出生年月
james = get_filedata(‘james2.txt’)
print (james[“name”]+”‘s fastest times are: ” + james[“times”])
print (james[“name”] + “‘s birthday is: ”  +
james[“date_of_birth”])

*    *name_birthday ={}.fromkeys(list_person_name)

#输出julie的排行前叁的不重复战绩和出生年月
julie = get_filedata(‘julie2.txt’)
print (julie[“name”]+”‘s fastest times are: ” + julie[“times”])
print (julie[“name”] + “‘s birthday is: ”  +
julie[“date_of_birth”])

   # 生成生日

#出口mikey的排名前叁的不重复成绩和出生年月
mikey = get_filedata(‘mikey2.txt’)
print (mikey[“name”]+”‘s fastest times are: ” + mikey[“times”])
print (mikey[“name”] + “‘s birthday is: ”  +
mikey[“date_of_birth”])

*    *for key in name_birthday:

#输出sarah的排行前3的不另行成绩和出生年月
sarah = get_filedata(‘sarah2.txt’)
print (sarah[“name”]+”‘s fastest times are: ” + sarah[“times”])
print (sarah[“name”] + “‘s birthday is: ”  +
sarah[“date_of_birth”])

       temp_year = randint(1990, 1999)

通过创立继续内置list的类AthleteList,将艺术定义在类中落到实处均等效果:

       temp_month = randint(1, 12)

复制代码 代码如下:

       temp_day = randint(1, 30)

import os
print(os.getcwd())
os.chdir(‘C:\Python33\HeadFirstPython\hfpy_code\chapter6’) 
#将工作空间修改为文件所在的目录

       name_birthday[key] = date(temp_year, temp_month, temp_day)

#定义类AthleteList继承python内置的list
class AthleteList(list):
    def __init__(self, name, dob=None, times=[]):
        list.__init__([])
        self.name=name
        self.dob=dob
        self.extend(times)
    def get_prev_three(self):
        return (sorted(set([modify_time_format(t) for t in
self]))[0:3])

   # 返回

def get_filedata(filename):
    try:
        with open(filename)  as f:        #with语句张开和自动关闭文件
            data=f.readline()                 #从文件中逐行读取字符
            data_list=data.strip().split(‘,’)  
#将字符间的空格清除后,用逗号分隔字符
            return(
                   AthleteList(data_list.pop(0), data_list.pop(0),
data_list)
                   )                               
#选取字典将关联的姓名,出生年月,时间键和值实行仓库储存并回到
    except IOError as ioerr:
        print (‘File Error’ + str(ioerr))     #格外管理,打印错误
        return (None)

*    *return name_birthday

def modify_time_format(time_string):
    if “-” in time_string:
        splitter=”-“
    elif “:” in time_string:
        splitter=”:”
    else:
        splitter=”.”
    (mins, secs)=time_string.split(splitter)
#用分隔符splitter分隔字符后分别存入mins和secs
    return (mins+ ‘.’ +secs)

 

james = get_filedata(‘james2.txt’)
print (james.name+”‘s fastest times are: ” +
str(james.get_prev_three()))

def person_birthday_summer(name_birthday:dict):

julie = get_filedata(‘julie2.txt’)
print (julie.name+”‘s fastest times are: ” +
str(julie.get_prev_three()))

   # 用于存款和储蓄夏日落地的key

mikey = get_filedata(‘mikey2.txt’)
print (mikey.name+”‘s fastest times are: ” +
str(mikey.get_prev_three()))

*    *list_person = []

sarah = get_filedata(‘sarah2.txt’)
print (sarah.name+”‘s fastest times are: ” +
str(sarah.get_prev_three()))

   for key in name_birthday:

       if name_birthday[key].month
>= 6 and name_birthday[key].month <= 8:

            list_person.append(key)

   # 返回

*    *return list_person

 

 

def get_person_year_max(name_birthday:dict):

   # 在字典中领到出破壳日

*    *person_birth = list(name_birthday.values())

   # 获取最大的湖州

*    *max_birthday = sorted(person_birth)[len(person_birth)-1]

   # 遍历

*    *for key in name_birthday:

       if name_birthday[key] == max_birthday:

            return key

 

 

def get_person_year_min(name_birthday:dict):

   # 在字典中领抽取生日

*    *person_birth = list(name_birthday.values())

   # 获取最小的破壳日

*    *min_birthday = sorted(person_birth)[0]

   # 遍历

*    *for key in name_birthday:

       if name_birthday[key] == min_birthday:

            return key

 

def get_person_days(name_birthday:dict):

   # 在字典中提收取破壳日

*    *person_birth = list(name_birthday.values())

   # 获取最大的生辰

*    *min_birthday = sorted(person_birth)[0]

   max_birthday = sorted(person_birth)[len(person_birth)- 1]

   # 重返天数

*    *return (max_birthday-min_birthday).days

 

def get_person_early_birthday(name_birthday:dict):

   for key in name_birthday:

       name_birthday[key] = name_birthday[key].replace(year=1990)

 

   person_birth = list(name_birthday.values())

   return(sorted(person_birth)[0])

 

def get_person_later_birthday(name_birthday:dict):

   for key in name_birthday:

       name_birthday[key] = name_birthday[key].replace(year=1990)

 

   person_birth = list(name_birthday.values())

   return(sorted(person_birth)[len(person_birth)-1])

 

 

if __name__ == “__main__”:

   list_name =
[“赵一”“杨二”“张三”“李四”“王五”“赵六”“马七”“郑八”“刘九”,“胡十”]

# 为list_name中持有的学习者生成生日

*    *name_birthday = build_birthday(list_name)

   print(name_birthday)

   # 调用功效模块

*    *birthday_summer_list =person_birthday_summer(name_birthday)

   if len(birthday_summer_list) == 0:

       print(“未有人的风水是在夏日: “)

   else:

       print(“寿辰为夏日的有:”,
birthday_summer_list)  # 需求一

*    # 需求二*

*    *print(“出生之日最大的:”, get_person_year_max(name_birthday))

   print(“出生之日最小的:”, get_person_year_min(name_birthday))

   print(“最大比最小的造化:”, get_person_days(name_birthday))

   # 需求三

*    *date_early =get_person_early_birthday(name_birthday)

   print(“出生之日最大的是:%d月%d日”%(date_early.month,date_early.day))

 

   date_later = get_person_later_birthday(name_birthday)

   print(“寿辰最小的是:%d月%d日” % (date_later.month,
date_early.day))

 

推行结果:

C:\python\python.exeC:/python/demo/file3.py

{‘赵一’:datetime.date(1992, 12, 30), ‘杨二’: datetime.date(1995,6, 23),
‘张三’: datetime.date(1990, 6, 21), ‘李四’:datetime.date(1991, 9, 29),
‘王五’:datetime.date(1996, 2, 26), ‘赵六’:datetime.date(1995, 9, 18),
‘马七’:datetime.date(1996, 7, 4), ‘郑八’:datetime.date(1990, 3, 5),
‘刘九’:datetime.date(1992, 3, 3), ‘胡十’:datetime.date(1992, 11, 6)}

三亚为夏日的有: [‘杨二’,’张三’,’马七’]

威海最大的: 马七

黄冈最小的: 郑八

最大比最小的大运: 23一3

破壳日最大的是:7月2二十23日

出生之日最小的是:七月二十四日

 

Process finished with exit code 0


相关文章

发表评论

电子邮件地址不会被公开。 必填项已用*标注

网站地图xml地图