Hi,小弟我现在有一个数据,是按照每天计算出来的tp.对应的数据为
<code>["2011-1-1","2011-1-2","2011-1-3","2011-1-4",...] </code>
每一天对应的数据(tp)
<code>[1,2,2,3,...] </code>
那么现在要讲这些日期按照周分类,没就是计算的结果为
<code>["2011年第一周",...] </code>
数据为
<code>[8,...] </code>
那么现在该怎么做呢?? 用什么语言实现都无所谓~~~~
回复内容:
Hi,小弟我现在有一个数据,是按照每天计算出来的tp.对应的数据为
<code>["2011-1-1","2011-1-2","2011-1-3","2011-1-4",...] </code>
每一天对应的数据(tp)
<code>[1,2,2,3,...] </code>
那么现在要讲这些日期按照周分类,没就是计算的结果为
<code>["2011年第一周",...] </code>
数据为
<code>[8,...] </code>
那么现在该怎么做呢?? 用什么语言实现都无所谓~~~~
<code><?php $date_list = null; $num_list = null; $index = 0; while($index < 20) { $date_list[] = date('Y-m-d',strtotime('-' . $index . ' day')); $num_list[] = $index; $index++; } // 先别管上面的代码,只是为了生成你的数据 $ret_list = null; // 假设日期数组和值数组的索引一致 foreach($date_list as $k => $date) { if($ret_list[date('W', strtotime($date))]) { $ret_list[date('W', strtotime($date))] += $num_list[$k]; } else { $ret_list[date('W', strtotime($date))] = $num_list[$k]; } } echo("日期数组:<br>"); print_r($date_list); echo("<br>"); echo("数值数组:<br>"); print_r($num_list); echo("<br>"); echo("按周统计数组(数组的键就是今年的第几周):<br>"); print_r($ret_list); </code>
重点在于date函数的使用,如何获取日期属于年度的第几周,看看php的doc吧。
var datas = ["2011-1-1","2011-1-2","2011-1-3","2011-1-4",...] function toWeekAarry(data){ var dateArr ,dateObj ,currWeek = 0; ,weeks = []; //假设楼主的数据不是连续的,而且不是全部元素合法 datas.filter(dateStr=>typeof dateStr==="string").forEach(dateStr=>{ dateArr = dateStr.split("-") if(dateArr.length===3){ dateObj = new Date(dateArr[0],dateArr[1],dateArr[2]) currWeek = getWeekOfDate(dateObj) if(!weeks[])weeks[currWeek]=[] weeks[currWeek].push(date); } }) retrun weeks.map(week=>if(!week)week=[]); } //返回结果是一个按照第几周组成的复合数组。
getWeekOfDate方法来自 http://stackoverflow.com/questions/9045868/javascript-date-getweek
function getWeekOfDate (dateObj,dowOffset) { dowOffset = typeof(dowOffset) == 'int' ? dowOffset : 0; //default dowOffset to zero var newYear = new Date(dateObj.getFullYear(),0,1); var day = newYear.getDay() - dowOffset; //the day of week the year begins on day = (day >= 0 ? day : day + 7); var daynum = Math.floor((dateObj.getTime() - newYear.getTime() - (dateObj.getTimezoneOffset()-newYear.getTimezoneOffset())*60000)/86400000) + 1; var weeknum; //if the year starts before the middle of a week if(day < 4) { weeknum = Math.floor((daynum+day-1)/7) + 1; if(weeknum > 52) { nYear = new Date(dateObj.getFullYear() + 1,0,1); nday = nYear.getDay() - dowOffset; nday = nday >= 0 ? nday : nday + 7; /*if the next year starts before the middle of the week, it is week #1 of that year*/ weeknum = nday < 4 ? 1 : 53; } } else { weeknum = Math.floor((daynum+day-1)/7); } return weeknum; };
1)计算日期对应的周信息
<code>function getWeekOfYear(date){ var year=date.getFullYear(); var baseDate=new Date(year,0,1); var baseWeekDay=testDate.getDay(); var dateWeekDay=date.getDay(); if(baseWeekDay==0) baseWeekDay=7; if(dateWeekDay==0) dateWeekDay=7; var weekOfYear=Math.round(((date.getTime()-dateWeekDay*3600*24*1000)-(baseDate.getTime()-baseWeekDay*3600*24*1000))/(24*3600*1000)/7); return weekOfYear+1; }</code>
2)将在同一周的数据相加
<code> var dateArray=["2011-1-1","2011-1-2","2011-1-3","2014-10-01",'2014-01-01','2015-11-11']; var dateTpArray=[9,8,7,6,121323445,23492742742374324]; var dateReg=/^(\d{4})\-(\d{1,2})\-(\d{1,2})$/; var reduceResult={}; dateArray.forEach(function(item,index){ var matchResult=dateReg.exec(item); console.log('%s %s %s',matchResult[1],matchResult[2],matchResult[3]); var weekOfYear=getWeekOfYear(new Date(parseInt(matchResult[1],10),parseInt(matchResult[2],10)-1,parseInt(matchResult[3],10))); if(!reduceResult[matchResult[1]+'_'+weekOfYear]){ reduceResult[matchResult[1]+'_'+weekOfYear]={ desc:matchResult[1]+'第'+weekOfYear+'周', tps:0 } } reduceResult[matchResult[1]+'_'+weekOfYear].tps=reduceResult[matchResult[1]+'_'+weekOfYear].tps+dateTpArray[index]; }); var weekOfYearDescArray=[]; var weekofYearTpArray=[]; for(var prop in reduceResult){ if(reduceResult.hasOwnProperty((prop))){ weekOfYearDescArray.push(reduceResult[prop].desc); weekofYearTpArray.push(reduceResult[prop].tps); } } console.log(weekOfYearDescArray); console.log(weekofYearTpArray);</code>

php把负数转为正整数的方法:1、使用abs()函数将负数转为正数,使用intval()函数对正数取整,转为正整数,语法“intval(abs($number))”;2、利用“~”位运算符将负数取反加一,语法“~$number + 1”。

实现方法:1、使用“sleep(延迟秒数)”语句,可延迟执行函数若干秒;2、使用“time_nanosleep(延迟秒数,延迟纳秒数)”语句,可延迟执行函数若干秒和纳秒;3、使用“time_sleep_until(time()+7)”语句。

php字符串有下标。在PHP中,下标不仅可以应用于数组和对象,还可应用于字符串,利用字符串的下标和中括号“[]”可以访问指定索引位置的字符,并对该字符进行读写,语法“字符串名[下标值]”;字符串的下标值(索引值)只能是整数类型,起始值为0。

php除以100保留两位小数的方法:1、利用“/”运算符进行除法运算,语法“数值 / 100”;2、使用“number_format(除法结果, 2)”或“sprintf("%.2f",除法结果)”语句进行四舍五入的处理值,并保留两位小数。

判断方法:1、使用“strtotime("年-月-日")”语句将给定的年月日转换为时间戳格式;2、用“date("z",时间戳)+1”语句计算指定时间戳是一年的第几天。date()返回的天数是从0开始计算的,因此真实天数需要在此基础上加1。

在php中,可以使用substr()函数来读取字符串后几个字符,只需要将该函数的第二个参数设置为负值,第三个参数省略即可;语法为“substr(字符串,-n)”,表示读取从字符串结尾处向前数第n个字符开始,直到字符串结尾的全部字符。

方法:1、用“str_replace(" ","其他字符",$str)”语句,可将nbsp符替换为其他字符;2、用“preg_replace("/(\s|\ \;||\xc2\xa0)/","其他字符",$str)”语句。

查找方法:1、用strpos(),语法“strpos("字符串值","查找子串")+1”;2、用stripos(),语法“strpos("字符串值","查找子串")+1”。因为字符串是从0开始计数的,因此两个函数获取的位置需要进行加1处理。


热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

AI Hentai Generator
免费生成ai无尽的。

热门文章

热工具

SecLists
SecLists是最终安全测试人员的伙伴。它是一个包含各种类型列表的集合,这些列表在安全评估过程中经常使用,都在一个地方。SecLists通过方便地提供安全测试人员可能需要的所有列表,帮助提高安全测试的效率和生产力。列表类型包括用户名、密码、URL、模糊测试有效载荷、敏感数据模式、Web shell等等。测试人员只需将此存储库拉到新的测试机上,他就可以访问到所需的每种类型的列表。

EditPlus 中文破解版
体积小,语法高亮,不支持代码提示功能

适用于 Eclipse 的 SAP NetWeaver 服务器适配器
将Eclipse与SAP NetWeaver应用服务器集成。

Atom编辑器mac版下载
最流行的的开源编辑器

PhpStorm Mac 版本
最新(2018.2.1 )专业的PHP集成开发工具