数据课程设计代码

OD拆分

import csv
import pandas as pd
lines=list(csv.reader(open(r"D:\大四上\数据课程设计\two_plate_data.csv",encoding='ansi')))
print('\n一共{0}条数据。'.format(str(lines.shape[0])))  # 一共46381313条数据。
header,values=lines[0],lines[1:]
data_dict={h:v for h,v in zip(header,zip(*values))}
#print(data_dict)
df=pd.DataFrame(data_dict)#转换成dataframe格式

#排序
df = df.astype({'plate_number':'str','time':'int','whether_operation':'int'})
df.sort_values(by=['plate_number','time'])

#转到列表
data=[]
data=df.values.tolist()
data.sort(key=lambda x:(x[4],x[5]))

#OD划分
n=len(df)
od=[]
for i in range(n-1):
    if data[i][4]==data[i+1][4] and (data[i][6]-data[i+1][6])==-1:
        od.append(data[i])
    if data[i][4]==data[i+1][4] and (data[i][6]-data[i+1][6])==1:
        od.append(data[i])       

#OD并行,计算出行时长
def timegap(t1,t2):
    T1=0
    T2=0
    T1+=t1%100+int(t1/100)%100*60+int(t1/10000)*3600
    T2+=t2%100+int(t2/100)%100*60+int(t2/10000)*3600
    T=T2-T1
    return T
od1=[]
m=len(od)
for j in range(0,m-2,2):
    od1.append([od[j][4],od[j][2],od[j][3],od[j][5],od[j+1][2],od[j+1][3],od[j+1][5]])
for l in range(len(od1)):
    od1[l].append(timegap(od1[l][3],od1[l][6]))

栅格处理


import pandas as pd
import matplotlib.pyplot as plt
import numpy as np
import seaborn as sns
import datetime

start = datetime.datetime.now() # 读数据计时
f = open(r'D:/大四上/数据课程设计/3.csv',encoding='utf-8',errors='ignore')
unsettled_od = pd.read_csv(f,header=0)
f = open(r'D:/大四上/数据课程设计/小区.csv',encoding='utf-8',errors='ignore')#小区表格由shape栅格文件导出
grid = pd.read_csv(f,header=0)
#unsettled_od = pd.read_csv(f,names = ['plate_number','O_date','O_lat', 'O_lon','O_time','O',
#                             'D_date','D_lat', 'D_lon','D_time','D','timegap'])
#unsettled_od.rename(columns = {'index','plate_number','O_date','O_lat', 'O_lon','O_time','O',
#                             'D_date','D_lat', 'D_lon','D_time','D','timegap'},inplace = True)
unsettled_od['is_out']='1'
unsettled_od['o_grid']='9999'
unsettled_od['d_grid']='9999'
#unsettled_o = unsettled_od[['plate_number','timegap','O_date','O_lat', 'O_lon','O_time','o_grid']]
#unsettled_d = unsettled_od[['plate_number','timegap','D_date','D_lat', 'D_lon','D_time','d_grid']]
end = datetime.datetime.now()
print('读数据耗时:',end-start)

# 初步查看数据
print('原始od数据集:')
unsettled_od.head()


# In[] 编号计算
#输入左下角拐点坐标
lng0=113.751943
lat0=22.447837
delta_lng=0.019519038
delta_lat=0.017985323
column=45
row=24
lat_max=22.864748
lat_min=22.447837
lng_max=114.624187
lng_min=113.751943
#判断是否在区域内
def delete(lng1, lat1,lng2, lat2):
    if lat_min<lat1<lat_max and lat_min<lat2<lat_max and lng_min<lng1<lng_max and lng_min<lng2<lng_max:
        a=1
    else:
        a=0
    return [a]
result = pd.DataFrame(list(map(delete,unsettled_od['O_lon'],unsettled_od['O_lat'],unsettled_od['D_lon'],unsettled_od['D_lat'])))
unsettled_od['is_out']=result[0]
unsettled_od = unsettled_od[~(unsettled_od['is_out']==0)]#超出范围删除
#编号判断
def gridid(lng, lat):
    grid=(int((lat-lat0)/ delta_lat))*column+(int((lng-lng0)/ delta_lng))
    return [grid]

result = pd.DataFrame(list(map(gridid,unsettled_od['O_lon'],unsettled_od['O_lat'])))
unsettled_od['o_grid'] = result[0]
print('O点已成功编码!')

result = pd.DataFrame(list(map(gridid,unsettled_od['D_lon'],unsettled_od['D_lat'])))
unsettled_od['d_grid'] = result[0]
print('D点已成功编码!')
# In[] 小区统计

O_grid=pd.value_counts(unsettled_od['o_grid'])

D_grid=pd.value_counts(unsettled_od['d_grid'])

for i in O_grid.index:
    grid['O_count'][i]=O_grid[i]

for i in D_grid.index:
    grid['D_count'][i]=D_grid[i]


#判断方法:(Int((lat2-lat0)/ Δlat))*每行的栅格数+(Int((lng2-lng0)/ Δlng))
#j=0
#for j in unsettled_od.index:
#    #O点栅格编号1 D点栅格编号2
#    lat1=unsettled_od['O_lat'][j]
#    lng1=unsettled_od['O_lon'][j]
#    lat2=unsettled_od['D_lat'][j]
#    lng2=unsettled_od['D_lon'][j]
#    if lat_min<lat1<lat_max and lat_min<lat2<lat_max and lng_min<lng1<lng_max and lng_min<lng2<lng_max:     
#        unsettled_od['o_grid'][j]=(int((lat1-lat0)/ delta_lat))*column+(int((lng1-lng0)/ delta_lng))
#        o_num=unsettled_od['o_grid'][j]
#        grid['O_count'][[o_num]]=grid['O_count'][[o_num]]+1
#        unsettled_od['d_grid'][j]=(int((lat2-lat0)/ delta_lat))*column+(int((lng2-lng0)/ delta_lng))
#        d_num=unsettled_od['d_grid'][j]
#        grid['D_count'][[d_num]]=grid['D_count'][[d_num]]+1
#    else:
#        unsettled_od = unsettled_od[~(unsettled_od.index==j)]#超出范围删除

unsettled_od.to_csv('D:/大四上/数据课程设计/4.csv')
grid.to_csv('D:/大四上/数据课程设计/小区统计.csv')

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
第1章 记忆测试软件1.1. 设计内容1.2. 设计要求1.3. 总体设计1.4. 具体设计1.4.1. 运行效果与程序发布1.4.2. 主类Memory1.4.3. 方块 Block1.4.4. 记忆测试板MemoryTestPane1.4.5. 显示成绩 ShowRecord1.4.6. 记录成绩 Record1.4.7. 随机排列图标 RandomSetIcon1.4.8. 测试者 People1.5. 课程设计作业第2章 计算器2.1. 设计内容2.2. 设计要求2.3. 总体设计2.4. 具体设计2.4.1. 运行效果与程序发布2.4.2. 主类 ComputerPad2.4.3. 数值按钮NumberButton2.4.4. 运算符号按钮OperationButton2.5. 课程设计作业第3章 HANNOI-塔3.1. 设计内容3.2. 设计要求3.3. 总体设计3.4. 具体设计3.4.1. 运行效果与程序发布3.4.2. 主类 Tower3.4.3. Hannoi-塔 HannoiTower3.4.4. 塔点 TowerPoint3.4.5. 盘子 Disk3.5. 课程设计作业第4章 JPEG图象生成器4.1. 设计内容4.2. 设计要求4.3. 总体设计4.4. 具体设计4.4.1. 运行效果与程序发布4.4.2. 主类 MakeJPEG.java4.5. 课程设计作业第5章 标准化考试系统 (单机版)5.1. 设计内容5.2. 设计要求5.3. 总体设计5.4. 具体设计5.4.1. 运行效果与程序发布5.4.2. 主类EnglishTest5.4.3. 考试区域TestArea5.4.4. 读取试题 ReadTestquestion5.5. 课程设计作业第6章 标准化考试系统 (C/S网络版)6.1. 设计内容6.2. 设计要求6.3. 总体设计6.4. 具体设计6.4.1. 运行效果与程序发布6.4.2. 客户端主类Client6.4.3. 客户端选择试题界面ChoiceFile6.4.4. 客户端考试界面ClientTestArea6.4.5. 服务器端主类Server6.4.6. 服务器端读取试题 ReadTestquestion6.5. 课程设计作业第7章 标准化考试系统 (B/S网络版)7.1. 设计内容7.2. 设计要求7.3. 总体设计7.4. 具体设计7.4.1. 运行效果与程序发布7.4.2. 客户端主类ClientBS7.4.3. 客户端选择试题界面ChoiceFile7.4.4. 客户端考试界面ClientTestArea7.4.5. 服务器端主类Server7.4.6. 服务器端读取试题 ReadTestquestion7.5. 课程设计作业第8章 日历记事本8.1. 设计内容8.2. 设计要求8.3. 总体设计8.4. 具体设计8.4.1. 运行效果与程序发布8.4.2. 主类CalendarPad8.4.3. 记事本NotePad8.4.4. 年Year8.4.5. 月Month8.5. 课程设计作业18.6. 课程设计作业2第9章 学籍管理系统9.1. 设计内容9.2. 设计要求9.3. 总体设计9.4. 具体设计9.4.1. 运行效果与程序发布9.4.2. 主类StudentManager9.4.3. 录入界面StudentSituation9.4.4. 查询界面Inquest9.4.5. 修改界面ModifySituation9.4.6. 删除界面Delete9.4.7. 学生对象Student9.5. 课程设计作业第10章 图书查询系统 (B/S网络版)10.1. 设计内容10.2. 设计要求10.3. 总体设计10.4. 具体设计10.4.1. 运行效果与程序发布10.4.2. 客户端主类DatabaseClient10.4.3. 服务器端主类DatabaseServer10.5. 课程设计作业第11章 中国象棋打谱软件11.1. 设计内容11.2. 设计要求11.3. 总体设计11.4. 具体设计11.4.1. 运行效果与程序发布11.4.2. 主类 Chess11.4.3. 对弈棋盘ChessBoard11.4.4. 棋子ChessPiece11.4.5. 棋点 ChessPoint11.4.6. 走棋法则Rule11.4.7. 步骤MoveStep11.4.8. 记录棋谱MakeChessManual11.4.9. 棋谱演示Demon11.5. 课程设计作业111.6. 课程设计作业2第12章 魔板游戏12.1. 设计内容12.2. 设计要求12.3. 总体设计12.4. 具体设计12.4.1. 运行效果与程序发布12.4.2. 主类PuzzleFrame12.4.3. 魔板PuzzlePad12.4.4. 魔板中的点SquarePoint12.5. 课程设计作业第13章 挖雷游戏13.1. 设计内容13.2. 设计要求13.3. 总体设计13.4. 具体设计13.4.1. 运行效果与程序发布13.4.2. 主类Game13.4.3. 方块 Block13.4.4. 雷区 MineSquare13.4.5. 雷标数目 FindAroundMineMarkNumber13.4.6. 雷标判断 DetermineMineMarkIsRightOrWrong13.4.7. 成片挖开区域 DetermineDigArea13.4.8. 无雷连通区 FindSafeArea13.4.9. 随机布雷 RandomSetMine13.4.10. 周围地雷个数FindAroundMineNumber13.4.11. 显示剩余雷数CountMine13.4.12. 计时器TimeCount13.4.13. 英雄榜录入对话框Record13.4.14. 显示英雄榜对话框ShowRecord13.4.15. 挖雷成功DecideWinner13.5. 课程设计作业第14章 网络聊天室 (B/S模式)14.1. 设计内容14.2. 设计要求14.3. 总体设计14.4. 具体设计14.4.1. 运行效果与程序发布14.4.2. 客户端主类ClientChat14.4.3. 客户端输入妮称界面InputNameTextField14.4.4. 客户端聊天界面ChatArea14.4.5. 服务器端主类ChatServer14.5. 课程设计作业第15章 局域网络广播系统15.1. 设计内容15.2. 设计要求15.3. 总体设计15.4. 具体设计15.4.1. 运行效果与程序发布15.4.2. 客户端主类Receive15.4.3. 服务器端主类BroadCastWord15.5. 课程设计作业
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值