当前位置: 首页 > wzjs >正文

做任务赚q币的网站百度下载安装2021最新版

做任务赚q币的网站,百度下载安装2021最新版,政府网站建设常出现的问题,申请免费网站主页空间本题用到知识点:row_number(), union, date_sub(), to_timedelta()…… 目录 思路 pandas Mysql 思路 链接:报告系统状态的连续日期 思路: 判断连续性常用的一个方法,增量相同的两个列的差值是固定的。 让日期与行号 * 天数…

本题用到知识点:row_number(), union, date_sub(), to_timedelta()……

目录

思路

pandas

Mysql


思路

链接:报告系统状态的连续日期

思路:

判断连续性常用的一个方法,增量相同的两个列的差值是固定的。

让日期与行号 * 天数相减,连续的区域就会的得到相同的结果。

不同的连续区域得到不同结果(因为来连续到不连续,中间出现了增量不为1的情况。但是行号总是增量为1,所以下一个连续区域与行号的差值与上一个连续区域不同。)

如:1~2 连续,7~8连续,但是与行号的差值tag并不相同。

根据相同的tag分组后,找到分组种的最大最小时间分别作为开始时间和结束时间,

两个表都根据上述操作后之际纵向拼接后按照开始时间升序输出。

pandas

import pandas as pddef report_contiguous_dates(failed: pd.DataFrame, succeeded: pd.DataFrame) -> pd.DataFrame:f_date_vaild = (failed['fail_date'] >= '2019-01-01') & (failed['fail_date'] <= '2019-12-31')failed = failed[f_date_vaild]failed['tag'] = failed['fail_date'] - pd.to_timedelta(failed.index,unit='d')failed = failed.groupby(by='tag')['fail_date'].agg(start_date='min',end_date='max').reset_index()failed['tag'] = 'failed's_date_vaild = (succeeded['success_date'] >= '2019-01-01') & (succeeded['success_date'] <= '2019-12-31')succeeded = succeeded[s_date_vaild]succeeded['tag'] = succeeded['success_date'] - pd.to_timedelta(succeeded.index, unit='d')succeeded = succeeded.groupby(by='tag')['success_date'].agg(start_date='min', end_date='max').reset_index()succeeded['tag'] = 'succeeded'return pd.concat([succeeded,failed],axis=0).rename(columns={'tag':'period_state'}).sort_values(by='start_date',ascending=True)

中间结果示例:failed表获取tag后

Mysql

pandas直接使用index作为行号,mysql则使用排名row_number()来获得固定增量的行号。

with f as 
(
select fail_date,
row_number() over(order by fail_date asc) as rn from failed 
where fail_date between '2019-01-01' and '2019-12-31')
,fg as 
(
select 'failed' as period_state,
min(fail_date) as start_date,
max(fail_date) as end_date
from 
(
select 
fail_date,
date_sub(fail_date,interval rn  day) as tag
from f 
) t
group by tag
)
,
s as 
(
select success_date,
row_number() over(order by success_date asc) as rn from succeeded
where success_date between '2019-01-01' and '2019-12-31'
)
,
sg as 
(
select 'succeeded' as period_state,
min(success_date) as start_date,
max(success_date) as end_date
from 
(
select 
success_date,
date_sub(success_date,interval rn  day) as tag
from s 
) t
group by tag
)select * from 
(
(select * from fg)union all (select * from sg)
) t
order by start_date asc

http://www.dtcms.com/wzjs/408592.html

相关文章:

  • 网站布局有哪些百度的营销策略
  • 可以做外贸私单的网站软文文案案例
  • 国外服务器哪家好seo免费
  • 网上接单做网站拼多多搜索关键词排名
  • 页面设计在哪打开杭州优化外包哪里好
  • 登录广东省建设监理协会网站首页江苏网站推广公司
  • 可信网站验证 费用直通车怎么开
  • 免费模板网站制作长沙网站seo推广
  • 外企网站建设网站备案
  • wordpress 搜索出图片郑州seo推广
  • 推广软件是什么新区seo整站优化公司
  • 广州 网站开发百度图片查找
  • 建设网站需要哪些费用制作网站要多少费用
  • 我自己的网站 怎样做防火墙seo网站监测
  • 哪个做简历的网站可以中英的免费注册二级域名的网站
  • 湖南网站制作重庆百度搜索优化
  • 线上设计师网站打开免费百度啊
  • 怎样用网站做淘宝客cms
  • 网站怎么优化seo广告设计自学教程
  • 云服务器做网站要备案吗网站宣传和推广的方法有哪些
  • 做网站uiseo快速工具
  • 网站服务类型是什么意思软文推广案例大全
  • 公司设计图图片简笔画优化大师怎么强力卸载
  • 做律师网站电销如何申请一个网站域名
  • 专门做设计的网站站长统计网站
  • 珠海pc网站建设网络营销ppt案例
  • 网站建设综合技术搜索网站的软件
  • 住房和城乡建设部网站防排烟网站开发月薪多少钱
  • 重庆企业公司网站建设网络销售新手入门
  • 网站建设的实训总结推广软文200字