400-650-7353
您所在的位置:首页 > 大学生就业 > 【实习报告】Python实训报告

【实习报告】Python实训报告

  • 来源:优就业
  • 2018-11-08 15:59:51
  • 阅读()
  • 分享
  • 手机端入口

#判断两次类聚中心点坐标

def random_kid_is_same(x_randomz_first,y_random_first,y_random_second,x_randomz_second):

if x_randomz_first==x_randomz_second and y_random_first==y_random_second :

a= False

else:

a=True

return a

a=random_kid_is_same(x_randomz_first,y_random_first,y_random_second,x_randomz_second)

print(a)

while a:

for i in range(0, len(x)):

for j in range(0, 3):

dic.append(math.sqrt((x[i] - x_randomz_first[j]) * (x[i] - x_randomz_first[j]) + (y[i] - y_random_first[j]) * (

y[i] - y_random_first[j])))#求距离

if dic[2] < dic[0] and dic[2] < dic[1]: # 2号距离最小

result_x_num2.append(x[i])

result_y_num2.append(y[i])

dic = []

elif dic[0] < dic[1] and dic[0] < dic[2]: # 0号距离最小

result_x_num0.append(x[i])

result_y_num0.append(y[i])

dic = []

elif dic[1] < dic[0] and dic[1] < dic[2]: # 1号最小

result_x_num1.append(x[i])

result_y_num1.append(y[i])

dic = []

for i_1 in range (0,len(result_x_num0)):#取0号类别里的数据

result_x+=result_x_num0[i_1]

#print(result_x_num0)

x_randomz_second.append(result_x/len(result_x_num0))

for i_3 in range (0,len(result_y_num0)):

result_y+=result_y_num0[i_3]

y_random_second.append(result_x/len(result_x_num0))

for i_2 in range (0,len(result_x_num1)):#取1号类别里的数据

result_x+=result_x_num1[i_2]

print(len(result_x_num1))

x_randomz_second.append(result_x /(len(result_x_num1)))

for i_4 in range (0,len(result_y_num1)):

result_y+=result_y_num1[i_4]

y_random_second.append(result_y/len(result_y_num1))

for i_5 in range(0, len(result_x_num2)):#取2号类别里的数据

result_x += result_x_num2[i_5]

x_randomz_second.append(result_x / len(result_x_num2))

for i_6 in range(0, len(result_y_num2)):

result_y += result_y_num2[i_6]

y_random_second.append(result_y / len(result_y_num2))

a=random_kid_is_same(x_randomz_first,y_random_first,y_random_second,x_randomz_second)

x_randomz_first=x_randomz_second

y_random_first=y_random_second

plt.scatter(result_x_num0,result_y_num0,color='black')

plt.scatter(result_x_num1,result_y_num1,color='red')

plt.scatter(result_x_num2,result_y_num2,color='green')

plt.legend(['第一类','第二类','第三类'])

plt.savefig('d:/home2.png')

plt.show()

Knn算法:

import matplotlib.pyplot as plt

import numpy as np

import random

from numpy import *

import math

#编程逻辑:

# 将原始的数据所有的属性分开存在数组中,顺序一致,将要配置的电影的信息都存在一个数组里,

# 用欧式公式求出相似度,将电影名称和相似度存放在字典里,对字典进行排序(从小到大),

# 然后按照排序出的结果根据电影名称查找每个电影对应的类型名称,将所有类型名称存在一个数组里

# 然后查找每种类型名称出现的次数,将类型名称和次数存放在字典里,在对字典进行排序(从大到小)

# 取出第一个数据的电影类型为要所求的电影类型,将此类型添加到要求的电影信息数组中

#数据准备

fill_name=['宝贝当家','美人鱼','澳门风云3','功夫熊猫3','谍影重重','叶问3','我的特工爷爷','奔爱','夜孔雀','代理情人','新步步惊心','伦敦沦陷']

funny_lens=[45,21,54,39,5,3,6,7,9,9,8,2]

hug_lens=[2,17,9,0,2,2,4,46,39,38,34,3]

fighting_lens=[9,5,11,31,57,65,21,4,8,2,17,55]

fill_type=['喜剧片','喜剧片','喜剧片','喜剧片','动作片','动作片','动作片','爱情片','爱情片','爱情片','爱情片','动作片']

fill_need_name=['唐人街探案',23,3,17]

#参数规定

k_numebr=4

result={}

dict={}

dict_result={}

dic=0

type_name=[]

count_fight=0

count1_fun=0

count1_love=0

#求出要求的电影的属性和样本点求距离

for i in range(0,len(fill_name)):

dic= math.sqrt((fill_need_name[1]-funny_lens[i])**2+(fill_need_name[2]-hug_lens[i])**2+(fill_need_name[3]-fighting_lens[i])**2)

result[fill_name[i]]=dic

#将数列排序 按value的值从小到大进行排序 给dict 此时dict的类型为list- list里的每一个元素为元组类型

dict= sorted(result.items(), key=lambda d:d[1], reverse = False)

print("相似度排序:-----------------")

for i in range (0,k_numebr):#按照要求k值进行截取

a=list(dict[i])#dict为list型 但是list中每一个元素为元组型,需要再转换为list型

print(a)#打印出按从小带大的排序取前k个

#按照电影名称查找每个电影的类型

for j in range(0,len(fill_name)):

if fill_name[j]==a[0]:

type_name.append(fill_type[j])

#遍历出来的所有电影类型名称 查找每个电影的类型出现的次数 存放到字典里

for i in range (0,len(type_name)):

if type_name[i]=='动作片':

count_fight+=1

elif type_name[i]=='喜剧片':

count1_fun+=1

elif type_name[i]=='爱情片':

count1_love+=1

dict_result['动作片']=count_fight

dict_result['喜剧片']=count1_fun

#print(type_name)

print("相似度前四个所对应的电影类型出现的次数-----------")

print(dict_result)

#将存放电影类型的字典按照出现次数的大小从大到小排列 此时dict_2为list型,list中每一个元素为元组型

dict_2= sorted(dict_result.items(), key=lambda d:d[1], reverse = True)

b=list(dict_2[0])#把list中第一个元组转换成数组 再取第一个数据为 所需要的类型

#print(b[0])

#将 找到的电影类型添加到原来电影信息的数组中

fill_need_name.append(b[0])

print("所求结果:-----------------")

print(fill_need_name)

5)python面向程序和爬虫

Python可以面向过程编程也可以面向对象编程,爬虫是从网页下载指定的格式的内容

class Human():

def __init__(self,name,age):

self._name=name

self._age=age

def talk(self):

print("Human can talk")

def display(self):

print(self._name+"-"+str(self._age))

def __str__(self):

return self._name+"-"+str(self._age)

def __repr__(self):

return self.__str__()

def getAge(self):

return self._age

def add_human(name,age):

s=Human(name,age)

return s

name='小刚'

age=22

a=add_human(name,age)

print(a)

import urllib.request

import re

def get_html(url):

page=urllib.request.urlopen(url)

html=page.read()

return html

reg= r'src=" (.+?\.jpg)" .width '

reg_img=re.compile(reg)#编译

html=get_html('http://tieba.baidu.com/p/1753935195')

html=html.decode('utf-8')

imglist=reg_img.findall(html)

三、心得总结

在大数据和云计算快速的发展的今天,python以语法简单功能强大成为学习大数据的一个理想的编程语言,在用python语言编程的时候发现跟其他语言有着明显的区别,python简化在其他语言中相对复杂繁琐的语法结构,但是在集成开发软件中,python需要按照严格的格式编程,如java是以分号作为程序结束的标记,并不要求在编程中需要有格式要求,然后python集成工具中写程序需要按照格式编程,这点在刚开始编程是会找不清每个部分所对应的级别,会造成很多编程错误,而当熟悉这种格式要求时,发现python这种简洁的要求更加简化的编程过程,编程速度也会有很大提高,逻辑也会更加清晰

Python中的变量并不需要提前设定变量类型,系统是自动添加数据类型,所以在编程中,要把握准确很大变量的类型,尤其在和元组,数组,字典相互使用的时候要注意类型的变化

个人认为在python编程中最重要的一步是在进行编程时想明白每个数组是用什么数据类型进行存放,当确定好数据类型后,python以它简单强大的语法,会使编程变得更加效率和简单!

相关推荐

【Python培训 】从小白到大咖 打造Python精英人才

【Python入门免费课程】引领编程开发新趋势

文章“【实习报告】Python实训报告”已帮助

>>本文地址:https://www.ujiuye.com/dxs/2018/45463.html

THE END  

声明:本站稿件版权均属中公教育优就业所有,未经许可不得擅自转载。

1 您的年龄

2 您的学历

3 您更想做哪个方向的工作?

获取测试结果
  • 大前端大前端
  • 大数据大数据
  • 互联网营销互联网营销
  • JavaJava
  • Linux云计算Linux
  • Python+人工智能Python
  • 嵌入式物联网嵌入式
  • 全域电商运营全域电商运营
  • 软件测试软件测试
  • 室内设计室内设计
  • 平面设计平面设计
  • 电商设计电商设计
  • 网页设计网页设计
  • 全链路UI/UE设计UI设计
  • VR/AR游戏开发VR/AR
  • 网络安全网络安全
  • 新媒体与短视频运营新媒体
  • 直播带货直播带货
  • 智能机器人软件开发智能机器人
 

快速通道fast track

近期开班时间TIME