python第五、六次作业

取系统时间

转换成‘2017年9月30日星期六10时28分56秒’格式字符串

’2018-10-25 22:00‘转换成一个日期时间变量

计算两者的间隔

 

二、问题:

  • 数列:
  • a = a1,a2,a3,·····,an
  • b = b1,b2,b3,·····,bn
  • 求:
  • c = a12+b13,a22+b23,a32+b33,·····+an2+bn3

1.用列表+循环实现,并包装成函数

2.用numpy实现,并包装成函数

3.对比两种方法实现的效率,给定一个较大的参数n,用运行函数前后的timedelta表示。

 

三、尝试把a,b定义为三层嵌套列表和三维数组,求相对应元素的ai2+bi3

对比两种数据类型处理方法及效率的不同。

 

 

 

1
2
3
4
5
6
7
8
9
10
11
12
13
14
import datetime
a=datetime.datetime(2019,5,8)
print(a)
b=datetime.datetime.now()
print(b)
from datetime import datetime
c=datetime.strptime('2017年9月30日星期六10时28分26秒','%Y年%m月%d日星期六10时28分26秒')
print(c)
d=b.strftime('%a, %b d %H:%M')
print(d)
print('今天是{0:%y}年的第{0:%j}天'.format(datetime.now()))
from datetime import timedelta
f=a-b
print('到2019年还有{}天'.format(f.days))

  

1
2
3
4
5
6
7
8
9
10
n=10
def numSum(n):
    a=list(range(n))
    b=list(range(0,n*5,5))
    c=[]
    for in range(len(a)):
        c.append(a[i]**2+b[i]**3)
    return (c)
 
print(numSum(n))

  

1
2
3
4
5
6
7
import numpy as np
def npSum(n):
    =np.arange(n)
    b= np.arange(0,n*5,5)
    c= a**2 + b**3
    return (c)
print(npSum(10))

  

1
2
3
4
5
6
7
8
9
10
11
12
13
from datetime import datetime
start = datetime.now()
 
from  Numpy import  numSum
numSum(10000)
delta = datetime.now()-start
print(delta)
 
from Numpy1 import  npSum
start = datetime.now()
npSum(10000)
delta = datetime.now()-start
print(delta)

  

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
import numpy
from datetime import  datetime
from Numpy import  numSum
from Numpy1 import   npSum
def listSum(n):
    = numpy.arange(n)
    = numpy.arange(0,5*n,5)
    = numpy.array([[a,b],[a**2,b**3]])
    return (c)
print(npSum(10))
 
start = datetime.now()
listSum(100000)
time = datetime.now()-start
print(time)

  

 

第六次作业

1. 安装scipy,numpy,sklearn包

2. 从sklearn包自带的数据集中读出鸢尾花数据集data

3.查看data类型,包含哪些数据

4.取出鸢尾花特征和鸢尾花类别数据,查看其形状及数据类型

5.取出所有花的花萼长度(cm)的数据

6.取出所有花的花瓣长度(cm)+花瓣宽度(cm)的数据

7.取出某朵花的四个特征及其类别。

8.将所有花的特征和类别分成三组,每组50个

9.生成新的数组,每个元素包含四个特征+类别

10.计算鸢尾花花瓣长度的最大值,平均值,中值,均方差。

11.显示鸢尾花某一特征的曲线图,散点图。

 

from sklearn.datasets import load_iris
import numpy as np
data=load_iris()#鸢尾花数据集data
print(type(data))#查看数据集的类型
print(data.keys())#包含的数据
data_tgs=data ['target']##鸢尾花特征
data_tgsname=data['target_names']##鸢尾花的类别数据
data_ts=data_tgsname,data_tgs#鸢尾花特征和鸢尾花的类别数据
print(data_ts)#形状
print(type(data_ts))#数据类型
#取出所有花的花萼长度
data_sepal_l=np.array([x[0] for x in data['data']])
data_sepal_l
data_petal_l=[x[2] for x in data['data']]#所有花花瓣的长度
data_petal_w=[x[3] for x in data['data']]#所有花花瓣的宽度
data_petal_l_w=np.array([data_petal_l,data_petal_w])#所有花花瓣的长度和宽度
data_petal_l_w
#7某朵花的四个特征和类别
data_flower=(data['data'][0],data['target_names'][0])
data_flower
#8定义三个列表来存放不同类型花朵的类别
data_setosa=[]  #存放类为0的花朵
data_versicolor=[] #存放类为1的花朵
data_virginica=[] #存放类为2的花朵
len(data['data'])
for i in  range(0,150):
    if data['target'][i]==0:      #类别为setosa
        datas=data['data'][i].tolist()
        datas.append('setosa')
        print(data_setosa.append(datas))
    elif data['target'][i]==1:    #类别为versicolor
        datas=data['data'][i].tolist()
        datas.append('versicolor')
        data_versicolor.append(datas)
    else:
        datas=data['data'][i].tolist()#类别为virginica
        datas.append('virginica')
        data_virginica.append(datas)
#9形成新的数组来存放三个类别的花朵
new_data=(np.array([data_setosa,data_versicolor,data_virginica]))
print(new_data)

posted @ 2018-11-05 09:00  asymptote  阅读(236)  评论(0编辑  收藏  举报