pandas温差查询案例的实现

目录
  • 任务详情
  • 任务要求
  • 测试用例
  • 任务实现

任务详情

给定一各地 2016 年 1 月和 2 月各个时间点的温度表格,表格预览见页面下方。
数据表的第二列表示当前时间,数据表第一行第三列到第一行最后一列表示地点。
如:表格的第二行第三列 30.36 表示:Vancouver (温哥华)在 2016-01-01 00:00:00 这一时刻的温度是 30.36 度(华氏度)。
程序给定一个日期(date)和一个地点(place),要求返回该地在这个日期下的温差(摄氏度)。
注意:华氏度需要转换成摄氏度!
华氏度转摄氏度公式:摄氏度 = (华氏度 - 32) * 5 / 9
温差:某日最高温度 - 某日最低温度

任务要求

程序给定日期 date 和地点 place 的数据类型均是 str 类型;
程序返回结果的数据类型是 float 类型,如果最终结果是 numpy.float64 数据类型,请手动转换成 Python 原生的 float 数据类型;
结果需要四舍五入保留小数点后 2 位,请在得到最终结果后处理小数问题,否则可能导致结果有偏差。

测试用例

输入:date = ‘2月5日’,place = ‘Dallas’
输出:-5.05
解释:查询表格可知,Dallas 在 2月 5 日温度的最高值和最低值分别是 57.09 华氏度和 34.18 华氏度,
两者的温差是 22.91 华氏度,转换为摄氏度:(22.91 - 32) * 5 / 9 = -5.05

输入:date= ‘2月18日’,place = ‘Houston’
输出:-1.78
解释:查询表格可知,Dallas 在 2月 5 日温度的最高值和最低值分别是 75.7 华氏度和 46.9 华氏度,
两者的温差是 28.8 华氏度,转换为摄氏度:(28.8 - 32) * 5 / 9 = -1.7777…. ≈ 1.78

输入:date = ‘1月21日’,place = 'Las Vegas’
输出:-1.99

任务实现

import pandas
class Solution:
    def temperature(self, date: str, place: str) -> float:
        # 将查询日期转换为日期字符串
        month, day_ = date.split("月")
        day, _ = day_.split("日")
        if len(month) == 1:
            month = "0" + month
        if len(day) == 1:
            day = "0" + day
        date_str = "2016" + "-" + month + "-" + day
        # 读取数据
        url = "http://ws1.itmc.org.cn:80/JS00101/data/user/4799/208/fj_4097_temperature_2016_1_2.csv"
        temperature_data = pandas.read_csv(url, sep=",")
        # 获取数据的日期字符串
        temperature_data["day"] = temperature_data["datetime"].str[:10]
        # 根据日期字符串选择指定日期数据行
        day = temperature_data[temperature_data["day"] == date_str]
        # 根据地点选择选择温度数据行
        city = day[place]
        # 温度单位转换
        temperature = (city.max() - city.min() - 32) * 5 / 9
        # 温度精度处理
        return float(temperature.round(2))

print(Solution.temperature(Solution, date="2月5日", place="Dallas"))
print(Solution.temperature(Solution, date="2月18日", place="Houston"))
print(Solution.temperature(Solution, date="1月21日", place="Las Vegas"))

输出为:

-5.05
-1.78
-1.99

到此这篇关于pandas温差查询案例的实现的文章就介绍到这了,更多相关pandas温差查询 内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

(0)

相关推荐

  • 浅谈pandas中Dataframe的查询方法([], loc, iloc, at, iat, ix)

    pandas为我们提供了多种切片方法,而要是不太了解这些方法,就会经常容易混淆.下面举例对这些切片方法进行说明. 数据介绍 先随机生成一组数据: In [5]: rnd_1 = [random.randrange(1,20) for x in xrange(1000)] ...: rnd_2 = [random.randrange(1,20) for x in xrange(1000)] ...: rnd_3 = [random.randrange(1,20) for x in xrange(1

  • 解决一个pandas执行模糊查询sql的坑

    查询引擎使用了presto,在sql中使用了模糊查询. engine = create_engine(presto_url,encoding='utf-8') sql_exe ="""select id,title,tags from source.base.table where tags like '%呵呵%' """ df = pd.read_sql_query(sql_exe,engine) 一直报错: unsupported forma

  • Python数据分析之 Pandas Dataframe修改和删除及查询操作

    目录 一.查询操作 元素的查询 二.修改操作 行列索引的修改 元素值的修改 三.行和列的删除操作 一.查询操作 可以使用Dataframe的index属性和columns属性获取行.列索引. import pandas as pd data = {"name": ["Alice", "Bob", "Cindy", "David"], "age": [25, 23, 28, 24], &q

  • pandas 像SQL一样使用WHERE IN查询条件说明

    in newDropList = [9,10,11,12,22,50,51,60,61] newDB = newDB[newDB['groupId'].isin(newDropList)] 直接查询表中groupId列,值为newDropList的记录 not in newDropList = [9,10,11,12,22,50,51,60,61] newDB = newDB[-newDB['groupId'].isin(newDropList)] 直接加一个" - " 号即可 补充知

  • Python数据分析之如何利用pandas查询数据示例代码

    前言 在数据分析领域,最热门的莫过于Python和R语言,本文将详细给大家介绍关于Python利用pandas查询数据的相关内容,分享出来供大家参考学习,下面话不多说了,来一起看看详细的介绍吧. 示例代码 这里的查询数据相当于R语言里的subset功能,可以通过布尔索引有针对的选取原数据的子集.指定行.指定列等.我们先导入一个student数据集: student = pd.io.parsers.read_csv('C:\\Users\\admin\\Desktop\\student.csv')

  • 详解pandas DataFrame的查询方法(loc,iloc,at,iat,ix的用法和区别)

    在操作DataFrame时,肯定会经常用到loc,iloc,at等函数,各个函数看起来差不多,但是还是有很多区别的,我们一起来看下吧. 首先,还是列出一个我们用的DataFrame,注意index一列,如下: 接下来,介绍下各个函数的用法: 1.loc函数 愿意看官方文档的,请戳这里,这里一般最权威. loc函数是基于"标签"选择数据的,但是也可以接受一个boolean的array,对于每个用法,我们从参数方面来一一举例: 1.1 单个label 接受一个"标签"(

  • pandas全表查询定位某个值所在行列的方法

    如下所示: # create a dataframe with an integer feature and a categorical string feature demo_df = pd.DataFrame({'Integer Feature': [0, 1, 2, 1], 'Categorical Feature': ['socks', 'fox', 'socks', 'box']}) demo_df 接下来用for遍历: for indexs in demo_df.index: for

  • Pandas 模糊查询与替换的操作

    主要用到的工具:Pandas .fuzzywuzzy Pandas:是基于numpy的一种工具,专门为分析大量数据而生,它包含大量的处理数据的函数和方法, 以下为pandas中文API: 缩写和包导入 在这个速查手册中,我们使用如下缩写: df:任意的Pandas DataFrame对象 s:任意的Pandas Series对象 同时我们需要做如下的引入: import pandas as pd import numpy as np 导入数据 pd.read_csv(filename):从CSV

  • Pandas使用query()优雅的查询实例

    目录 常规用法 多条件查询 引用变量 索引选取 多索引选取 特殊字符 对于 Pandas 根据条件获取指定数据,相信大家都能够轻松的写出相应代码,但是如果你还没用过 query,相信你会被它的简洁所折服! 常规用法 先创建一个 DataFrame. import pandas as pd df = pd.DataFrame(     {'A': ['e', 'd', 'c', 'b', 'a'],      'B': ['f', 'b', 'c', 'd', 'e'],      'C': ra

  • pandas 查询函数query的用法说明

    query() 函数简介 pandas的query()方法是基于DataFrame列的计算代数式,对于按照某列的规则进行过滤的操作,可以使用query方法. 代码示例 import pandas as pd df = pd.DataFrame({'a':[1, 2, 3, 4, 5, 6], 'b':[1, 2, 3, 4, 5, 6], 'c':[1, 2, 3, 4, 5, 6]}) query_list = [1, 2] df_2 = df.query('c not in @query_l

随机推荐