php实现按天数、星期、月份查询的搜索框

本文实例为大家分享了php实现按天数、星期、月份查询的搜索框,搜索时候展示数据的统计图,主要展示图形的效果,供大家参考,具体内容如下

1.ajax.php

$year = $_GET['y']; if(!isset($_GET['m'])){ $month=1; }else{ $month = $_GET['m']; } $week_arr = getMonthWeekArr($year,$month); echo json_encode($week_arr); die;

/**

  • 获得系统某月的周数组,第一周不足的需要补足
  • @param int $current_year
  • @param int $current_month
  • @return string[][]
    */
    function getMonthWeekArr($current_year,$current_month){

//该月第一天
$firstday = strtotime($current_year.'-'.$current_month.'-01');
//该月的第一周有几天
$firstweekday = (7 - date('N',$firstday) +1);
//计算该月第一个周一的时间
$starttime = $firstday-360024(7-$firstweekday);
//该月的最后一天
$lastday = strtotime($current_year.'-'.$current_month.'-01'." +1 month -1 day");
//该月的最后一周有几天
$lastweekday = date('N',$lastday);
//该月的最后一个周末的时间
$endtime = $lastday-360024($lastweekday%7);
$step = 3600247;//步长值
$week_arr = array();
for ($i=$starttime; $i<$endtime; $i= $i+3600247){
$week_arr[] = array('key'=>date('Y-m-d',$i).'|'.date('Y-m-d',$i+3600246),'val'=>date('Y-m-d',$i).'~'.date('Y-m-d',$i+3600246));
}
return $week_arr;
}

2.datehelper.php

//获得系统年份数组
/**

  • @return string[]
    */
    function getSystemYearArr(){
    $year_arr = array('2010'=>'2010','2011'=>'2011','2012'=>'2012','2013'=>'2013','2014'=>'2014','2015'=>'2015','2016'=>'2016','2017'=>'2017','2018'=>'2018','2019'=>'2019','2020'=>'2020');
    return $year_arr;
    }

/**

  • 获得系统月份数组
  • @return array
    */
    function getSystemMonthArr(){

$month_arr = array('1'=>'01','2'=>'02','3'=>'03','4'=>'04','5'=>'05','6'=>'06','7'=>'07','8'=>'08','9'=>'09','10'=>'10','11'=>'11','12'=>'12');
return $month_arr;
}

/**

  • 获得系统周数组
  • @return string[]
    */
    function getSystemWeekArr(){
    $week_arr = array('1'=>'周一','2'=>'周二','3'=>'周三','4'=>'周四','5'=>'周五','6'=>'周六','7'=>'周日');
    return $week_arr;
    }

/**

  • 获取某月的最后一天
  • @param int $year
  • @param int $month
  • @return number
    */
    function getMonthLastDay($year,$month){

$t = mktime(0,$month + 1,1,$year);
$t = $t - 60 60 24;
return $t;
}

/**

  • 获得系统某月的周数组,第一周不足的需要补足
  • @param int $current_year
  • @param int $current_month
  • @return string[][]
    /
    function getMonthWeekArr($current_year,$i+3600
    24*6));
    }
    return $week_arr;
    }

/**

  • 处理搜索时间
    */
    function dealwithSearchTime($search_arr=''){
    //初始化时间
    //天
    if(!isset($search_arr['search_time'])){
    $search_arr['search_time'] = date('Y-m-d',time()- 86400);
    }
$search_arr['day']['search_time'] = strtotime($search_arr['search_time']);//搜索的时间
//周
if(!isset($search_arr['searchweek_year'])){
  $search_arr['searchweek_year'] = date('Y',time());
}
if(!isset($search_arr['searchweek_month'])){
  $search_arr['searchweek_month'] = date('m',time());
}
if(!isset($search_arr['searchweek_week'])){
  $search_arr['searchweek_week'] = implode('|',getWeek_SdateAndEdate(time()));
}


$weekcurrent_year = $search_arr['searchweek_year'];
$weekcurrent_month = $search_arr['searchweek_month'];
$weekcurrent_week = $search_arr['searchweek_week'];
$search_arr['week']['current_year'] = $weekcurrent_year;
$search_arr['week']['current_month'] = $weekcurrent_month;
$search_arr['week']['current_week'] = $weekcurrent_week;

//月
if(!isset($search_arr['searchmonth_year'])){
  $search_arr['searchmonth_year'] = date('Y',time());
}
if(!isset($search_arr['searchmonth_month'])){
  $search_arr['searchmonth_month'] = date('m',time());
}
$monthcurrent_year = $search_arr['searchmonth_year'];
$monthcurrent_month = $search_arr['searchmonth_month'];
$search_arr['month']['current_year'] = $monthcurrent_year;
$search_arr['month']['current_month'] = $monthcurrent_month;
return $search_arr;

}

/**

  • 获取本周的开始时间和结束时间
  • @param int $current_time
  • @return string
    */
    function getWeek_SdateAndEdate($current_time){
$current_time = strtotime(date('Y-m-d',$current_time));
$return_arr['sdate'] = date('Y-m-d',$current_time-86400*(date('N',$current_time) - 1));
$return_arr['edate'] = date('Y-m-d',$current_time+86400*(7- date('N',$current_time)));

return $return_arr;

}
/**

  • 查询每月的周数组
    */
    function getweekofmonth(){
    $year = $_GET['y'];
    $month = $_GET['m'];
    $week_arr = getMonthWeekArr($year,$month);
    echo json_encode($week_arr);
    die;
    }

3.statistics.php

  • 统计
  • @abstract
  • @copyright 格里西,2016
  • @author liujun
  • @version Id:statics v1.0 2016/2/5
    */
  • /**

    • 获得折线图统计图数据
    • param $statarr 图表需要的设置项
    • @return string
      */
      function getStatData_LineLabels($stat_arr){

    //图表区、图形区和通用图表配置选项
    $stat_arr['chart']['type'] = 'line';
    //图表序列颜色数组
    $stat_arr['colors']?'':$stat_arr['colors'] = array('#058DC7','#ED561B','#8bbc21','#0d233a');
    //去除版权信息
    $stat_arr['credits']['enabled'] = false;
    //导出功能选项
    $stat_arr['exporting']['enabled'] = false;
    //标题如果为字符串则使用默认样式
    is_string($stat_arr['title'])?$stat_arr['title'] = array('text'=>"{$stat_arr['title']}",'x'=>-20):'';
    //子标题如果为字符串则使用默认样式
    is_string($stat_arr['subtitle'])?$stat_arr['subtitle'] = array('text'=>"{$stat_arr['subtitle']}",'x'=>-20):'';
    //Y轴如果为字符串则使用默认样式
    if(is_string($stat_arr['yAxis'])){
    $text = $stat_arr['yAxis'];
    unset($stat_arr['yAxis']);
    $stat_arr['yAxis']['title']['text'] = $text;
    }
    return json_encode($stat_arr);
    }

    /**

    • 获得Column2D统计图数据
    • @param array $stat_arr
    • @return string
      */
      function getStatData_Column2D($stat_arr){

    //图表区、图形区和通用图表配置选项
    $stat_arr['chart']['type'] = 'column';
    //去除版权信息
    $stat_arr['credits']['enabled'] = false;
    //导出功能选项
    $stat_arr['exporting']['enabled'] = false;
    //标题如果为字符串则使用默认样式
    is_string($stat_arr['title'])?$stat_arr['title'] = array('text'=>"{$stat_arr['title']}",'x'=>-20):'';
    //Y轴如果为字符串则使用默认样式
    if(is_string($stat_arr['yAxis'])){
    $text = $stat_arr['yAxis'];
    unset($stat_arr['yAxis']);
    $stat_arr['yAxis']['title']['text'] = $text;
    }
    //柱形的颜色数组
    $color = array('#7a96a4','#cba952','#667b16','#a26642','#349898','#c04f51','#5c315e','#445a2b','#adae50','#14638a','#b56367','#a399bb','#070dfa','#47ff07','#f809b7');

    foreach ($stat_arr['series'] as $series_k=>$series_v){
    foreach ($series_v['data'] as $data_k=>$data_v){
    $data_v['color'] = $color[$data_k];
    $series_v['data'][$data_k] = $data_v;
    }
    $stat_arr['series'][$series_k]['data'] = $series_v['data'];
    }
    //print_r($stat_arr); die;
    return json_encode($stat_arr);
    }

    /**

    • 获得Basicbar统计图数据
    • @param array $stat_arr
    • @return string
      */
      function getStatData_Basicbar($stat_arr){

    //图表区、图形区和通用图表配置选项
    $stat_arr['chart']['type'] = 'bar';
    //去除版权信息
    $stat_arr['credits']['enabled'] = false;
    //导出功能选项
    $stat_arr['exporting']['enabled'] = false;
    //显示datalabel
    $stat_arr['plotOptions']['bar']['dataLabels']['enabled'] = true;
    //标题如果为字符串则使用默认样式
    is_string($stat_arr['title'])?$stat_arr['title'] = array('text'=>"{$stat_arr['title']}",'#f809b7');

    foreach ($stat_arr['series'] as $series_k=>$series_v){
    foreach ($series_v['data'] as $data_k=>$data_v){
    if (!$data_v['color']){
    $data_v['color'] = $color[$data_k%15];
    }
    $series_v['data'][$data_k] = $data_v;
    }
    $stat_arr['series'][$series_k]['data'] = $series_v['data'];
    }
    //print_r($stat_arr); die;
    return json_encode($stat_arr);
    }

    /**

    • 计算环比
    • @param array $updata
    • @param array $currentdata
    • @return string
      */
      function getHb($updata,$currentdata){

    if($updata != 0){
    $mtomrate = round(($currentdata - $updata)/$updata*100,2).'%';
    } else {
    $mtomrate = '-';
    }
    return $mtomrate;
    }

    /**

    • 计算同比
    • @param array $updata
    • @param array $currentdata
    • @return string
      */
      function getTb($updata,$currentdata){

    if($updata != 0){
    $ytoyrate = round(($currentdata - $updata)/$updata*100,2).'%';
    } else {
    $ytoyrate = '-';
    }
    return $ytoyrate;
    }

    /**

    • 地图统计图
    • @param array $stat_arr
    • @return string
      */
      function getStatData_Map($stat_arr){

    //$color_arr = array('#f63a3a','#ff5858','#ff9191','#ffc3c3','#ffd5d5');
    $color_arr = array('#fd0b07','#f7ba17','#fef406','#25aae2');
    $stat_arrnew = array();
    foreach ($stat_arr as $k=>$v){
    $stat_arrnew[] = array('cha'=>$v['cha'],'name'=>$v['name'],'des'=>$v['des'],'color'=>$color_arr[$v['level']]);
    }
    return json_encode($stat_arrnew);
    }

    /**

    • 获得饼形图数据
    • @param array $data
    • @return string
      */
      function getStatData_Pie($data){

    $stat_arr['chart']['type'] = 'pie';
    $stat_arr['credits']['enabled'] = false;
    $stat_arr['title']['text'] = $data['title'];
    $stat_arr['tooltip']['pointFormat'] = '{series.name}: {point.y}';
    $stat_arr['plotOptions']['pie'] = array(
    'allowPointSelect'=>true,'cursor'=>'pointer','dataLabels'=>array(
    'enabled'=>$data['label_show'],'color'=>'#000000','connectorColor'=>'#000000','format'=>'{point.name}: {point.percentage:.1f} %'
    )
    );
    $stat_arr['series'][0]['name'] = $data['name'];
    $stat_arr['series'][0]['data'] = array();
    foreach ($data['series'] as $k=>$v){
    $stat_arr['series'][0]['data'][] = array($v['p_name'],$v['allnum']);
    }
    //exit(json_encode($stat_arr));
    return json_encode($stat_arr);
    }

    4.theline.php

    Echarts //获得系统年份 $year_arr = getSystemYearArr(); //获得系统月份 $month_arr = getSystemMonthArr(); //存储参数 $search_arr = $_REQUEST; $search_arr =dealwithSearchTime($search_arr); //获得本月的周时间段 $week_arr = getMonthWeekArr($search_arr['week']['current_year'],$search_arr['week']['current_month']); //天数 if(!isset($_REQUEST['search_time'])){ $_REQUEST['search_time'] = date('Y-m-d',time()-86400); } $search_time = $_REQUEST['search_time'];//搜索的时间 //周 if(!isset($_REQUEST['search_time_year'])){ $_REQUEST['search_time_year'] = date('Y',time()); } if(!isset($_REQUEST['search_time_month'])){ $_REQUEST['search_time_month'] = date('m',time()); } if(!isset($_REQUEST['search_time_week'])){ $_REQUEST['search_time_week'] = implode('|',getWeek_SdateAndEdate(time())); } $current_year = $_REQUEST['search_time_year']; $current_month = $_REQUEST['search_time_month']; $current_week = $_REQUEST['search_time_week'];

    ?>

      <div id="searchtype_month" style="display:none;"&gt;
          <select name="search_time_year" class="querySelect"&gt;
          <?php foreach ($year_arr as $k=>$v){?>
          <option value="<?php echo $k;?>" <?php echo $current_year == $k?'selected':'';?> ><?php echo $v; ?></option>
          <?php } ?>
        </select>
        <select name="search_time_month" class="querySelect"&gt;
          <?php foreach ($month_arr as $k=>$v){?>
          <option value="<?php echo $k;?>" <?php echo $current_month == $k?'selected':'';?>><?php echo $v; ?></option>
          <?php } ?>
        </select>
      </div> 

    <div id="line_chart" style="width:600px;height:400px;">


    <?php $thearray=array(11,11,15,13,12,10);?>
    <script type="text/javascript">
    // 基于准备好的dom,初始化echarts实例

    var mylineChart=echarts.init(document.getElementById('line_chart'));
    
    option1 = {

    title: {
    text: '未来一周气温变化',subtext: '纯属虚构'
    },tooltip: {
    trigger: 'axis'
    },legend: {
    data:['最高气温','最低气温']
    },toolbox: {
    show: true,feature: {
    dataZoom: {},// dataView: {readOnly: false},magicType: {type: ['line','bar']},restore: {},saveAsImage: {}
    }
    },xAxis: {
    type: 'category',boundaryGap: false,data: ['周一','周二','周三','周四','周五','周六','周日']
    },yAxis: {
    type: 'value',axisLabel: {
    formatter: '{value} °C'
    }
    },series: [
    {
    name:'最高气温',type:'line',data:<?php echo(json_encode($thearray)); ?>,markPoint: {
    data: [
    {type: 'max',name: '最大值'},{type: 'min',name: '最小值'}
    ]
    },markLine: {
    data: [
    {type: 'average',name: '平均值'}
    ]
    }
    },{
    name:'最低气温',data:[1,4,2,5,3,0],markPoint: {
    data: [
    {name: '周最低',value: -2,xAxis: 1,yAxis: -1.5}
    ]
    },name: '平均值'}
    ]
    }
    }
    ]
    };
    // 使用刚指定的配置项和数据显示图表。
    mylineChart.setOption(option1);

    5.time_deal.php

    //获取系统年份
    /**

    • @return string[]
      */
      function getSystemYearArr(){

    $year_arr = array('2010'=>'2010','12'=>'12');
    return $month_arr;
    }

    /**

    • 处理搜索时间
      */
      public function dealwithSearchTime($search_arr){
      //初始化时间
      //天
      if(!$search_arr['search_time']){
      $search_arr['search_time'] = date('Y-m-d',time()- 86400);
      }
      $search_arr['day']['search_time'] = strtotime($search_arr['search_time']);//搜索的时间
    //周
    if(!$search_arr['searchweek_year']){
      $search_arr['searchweek_year'] = date('Y',time());
    }
    if(!$search_arr['searchweek_month']){
      $search_arr['searchweek_month'] = date('m',time());
    }
    if(!$search_arr['searchweek_week']){
      $search_arr['searchweek_week'] = implode('|',getWeek_SdateAndEdate(time()));
    }
    $weekcurrent_year = $search_arr['searchweek_year'];
    $weekcurrent_month = $search_arr['searchweek_month'];
    $weekcurrent_week = $search_arr['searchweek_week'];
    $search_arr['week']['current_year'] = $weekcurrent_year;
    $search_arr['week']['current_month'] = $weekcurrent_month;
    $search_arr['week']['current_week'] = $weekcurrent_week;
    
    //月
    if(!$search_arr['searchmonth_year']){
      $search_arr['searchmonth_year'] = date('Y',time());
    }
    if(!$search_arr['searchmonth_month']){
      $search_arr['searchmonth_month'] = date('m',time());
    }
    $monthcurrent_year = $search_arr['searchmonth_year'];
    $monthcurrent_month = $search_arr['searchmonth_month'];
    $search_arr['month']['current_year'] = $monthcurrent_year;
    $search_arr['month']['current_month'] = $monthcurrent_month;
    return $search_arr;

    }

    以上就是本文的全部内容,希望对大家的学习有所帮助。

    版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

    相关推荐


    如何选择合适的 C++ Web 开发框架?
    利用 C++ 框架构建高并发 Web 应用的策略
    用 C++ 框架开发跨平台图形应用程序
    golang框架中安全编码实践的最佳指南是什么?
    golang框架与其他语言框架在设计理念上的区别有哪些?
    C++ 图形框架与其他语言框架的比较
    C++ 框架与其他 Web 开发框架的对比分析
    使用 C++ 框架构建大型项目最佳实践
    C++ 框架如何提高大型项目开发效率
    C++ 框架中依赖注入的持续集成与部署工具
    如何与社区协作和贡献到自定义 Golang 框架?
    C++ 框架在大型项目中如何实现模块化开发
    使用 C++ 框架开发跨平台 Web 应用
    C++ 框架在大型项目中的优缺点
    golang框架在性能上的优势体现在哪些方面?
    C++ 框架在嵌入式系统内存优化中的优势
    golang框架在人工智能与机器学习中的作用
    如何扩展 Golang 框架以支持特定功能?
    如何利用 Go Modules 和依赖项管理来自定义 Golang 框架?
    Golang 框架中的性能优化技巧