phpは、日数、週、月によるクエリーの検索ボックスを実現します.

25418 ワード

本文の例はphpが日数、週、月によって検索を実現する検索ボックスを共有し、検索時にデータの統計図を展示し、主に図形の効果を展示し、参考に供し、具体的な内容は以下の通りである.
1.ajax.php

date('Y-m-d',$i).'|'.date('Y-m-d',$i+3600*24*6), 'val'=>date('Y-m-d',$i).'~'.date('Y-m-d',$i+3600*24*6));
  }
  return $week_arr;
}

2.datehelper.php

'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, 0, 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, $current_month){
   
  //     
  $firstday = strtotime($current_year.'-'.$current_month.'-01');
  //         
  $firstweekday = (7 - date('N',$firstday) +1);
  //            
  $starttime = $firstday-3600*24*(7-$firstweekday);
  //       
  $lastday = strtotime($current_year.'-'.$current_month.'-01'." +1 month -1 day");
  //          
  $lastweekday = date('N',$lastday);
  //            
  $endtime = $lastday-3600*24*($lastweekday%7);
  $step = 3600*24*7;//   
  $week_arr = array();
  for ($i=$starttime; $idate('Y-m-d',$i).'|'.date('Y-m-d',$i+3600*24*6), 'val'=>date('Y-m-d',$i).'~'.date('Y-m-d',$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

"{$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):'';
  //                
  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;
  }
  //       
  $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']}",'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;
  }
  //       
  $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){
      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','#ff9191','#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







  
    
// 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:' ', type:'line', data:[1, 4, 2, 5, 3, 2, 0], markPoint: { data: [ {name: ' ', value: -2, xAxis: 1, yAxis: -1.5} ] }, markLine: { data: [ {type: 'average', name: ' '} ] } } ] }; // 。 mylineChart.setOption(option1); // function show_searchtime(){ s_type = $("#search_type").val(); $("[id^='searchtype_']").hide(); $("#searchtype_"+s_type).show(); } $(function(){ show_searchtime(); $("#search_type").change(function(){ show_searchtime(); }); // $("[name='search_time_month']").change(function(){ var year = $("[name='search_time_year']").val(); var month = $("[name='search_time_month']").val(); $("[name='search_time_week']").empty(); $.getJSON('php/ajax.php',{y:year,m:month},function(data){ if(data != null){ for(var i = 0; i < data.length; i++) { $("[name='search_time_week']").append('<option value="'+data[i].key+'">'+data[i].val+'</option>'); } } }); }); // $("[name='search_time_year']").change(function(){ var year = $("[name='search_time_year']").val(); $("[name='search_time_week']").empty(); $("#searchweek_mouth option:first").prop("selected", 'selected'); $.getJSON('php/ajax.php',{y:year},function(data){ if(data != null){ for(var i = 0; i < data.length; i++) { $("[name='search_time_week']").append('<option value="'+data[i].key+'">'+data[i].val+'</option>'); } } }); }); });

5.time_deal.php

'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;
}
 
  /**
   *       
   */
  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;
  }


以上が本文のすべての内容で、みんなの学習に役立つことを望みます.