>

이 코드 스 니펫이 있습니다 :

foreach($data['matches'] as $record){
    $matchday = $record['matchday'];
    echo '<h4>Round'. $matchday  .'</h4><br>'.$record['homeTeam']['name'].'&nbsp;-&nbsp;'.$record['awayTeam']['name'].'<br>';
}

다차원 배열을 반복하여 경쟁의 모든 달력 일치를 표시합니다. matches  내가 사용하는 배열을 포함하는 키입니다. 헤더 <h4> 아래에 모든 라운드의 모든 경기를 표시하려면 매 시즌 라운드마다 매치 데이를 한 번만 추출하면됩니다.  뭔가 round 1 처럼 round 2  ecc. 모든 라운드에는 10 개의 일치 항목이 있으며 루프를 사용하여 현재 라운드에 대한 정보도 표시하면이 정보가 복제되지만 동일한 라운드에 속하는 경우 그룹화해야합니다. 이것을 달성 할 수 있습니까? 아이디어는 다음과 같은 것을 얻는 것입니다.

Round 1
team 1 - team 2
team 3 - team 4
team 5 - team 6
Round 2
team 1 - team 2
team 3 - team 4
team 5 - team 6
ecc..

현재 데이터가 다음과 같이 표시됩니다 :

Round 1
team 1 - team 2
Round 1
team 3 - team 4
Round 1
team 5 - team 6
Round 2
team 1 - team 2
Round 2
team 3 - team 4
Round 2
team 5 - team 6
ecc..

수정 여기 내가 일하고있는 배열이 있습니다 (첫 번째 라운드의 두 경기 만 가져갈 것입니다) :

   array(4) {
  ["count"]=>
  int(380)
  ["filters"]=>
  array(0) {
  }
  ["competition"]=>
  array(6) {
    ["id"]=>
    int(2019)
    ["area"]=>
    array(2) {
      ["id"]=>
      int(2114)
      ["name"]=>
      string(5) "Italy"
    }
    ["name"]=>
    string(7) "Serie A"
    ["code"]=>
    NULL
    ["plan"]=>
    string(8) "TIER_ONE"
    ["lastUpdated"]=>
    string(20) "2018-06-05T00:14:16Z"
  }
  ["matches"]=>
  array(380) {
    [0]=>
    array(12) {
      ["id"]=>
      int(247791)
      ["season"]=>
      array(4) {
        ["id"]=>
        int(290)
        ["startDate"]=>
        string(10) "2018-08-18"
        ["endDate"]=>
        string(10) "2019-05-26"
        ["currentMatchday"]=>
        int(1)
      }
      ["utcDate"]=>
      string(20) "2018-08-18T16:00:00Z"
      ["status"]=>
      string(9) "SCHEDULED"
      ["matchday"]=>
      int(1)
      ["stage"]=>
      string(14) "REGULAR_SEASON"
      ["group"]=>
      string(14) "Regular Season"
      ["lastUpdated"]=>
      string(20) "2018-08-01T18:02:07Z"
      ["homeTeam"]=>
      array(2) {
        ["id"]=>
        int(106)
        ["name"]=>
        string(16) "AC Chievo Verona"
      }
      ["awayTeam"]=>
      array(2) {
        ["id"]=>
        int(109)
        ["name"]=>
        string(11) "Juventus FC"
      }
      ["score"]=>
      array(6) {
        ["winner"]=>
        NULL
        ["duration"]=>
        string(7) "REGULAR"
        ["fullTime"]=>
        array(2) {
          ["homeTeam"]=>
          NULL
          ["awayTeam"]=>
          NULL
        }
        ["halfTime"]=>
        array(2) {
          ["homeTeam"]=>
          NULL
          ["awayTeam"]=>
          NULL
        }
        ["extraTime"]=>
        array(2) {
          ["homeTeam"]=>
          NULL
          ["awayTeam"]=>
          NULL
        }
        ["penalties"]=>
        array(2) {
          ["homeTeam"]=>
          NULL
          ["awayTeam"]=>
          NULL
        }
      }
      ["referees"]=>
      array(0) {
      }
    }
    [1]=>
    array(12) {
      ["id"]=>
      int(247786)
      ["season"]=>
      array(4) {
        ["id"]=>
        int(290)
        ["startDate"]=>
        string(10) "2018-08-18"
        ["endDate"]=>
        string(10) "2019-05-26"
        ["currentMatchday"]=>
        int(1)
      }
      ["utcDate"]=>
      string(20) "2018-08-18T18:30:00Z"
      ["status"]=>
      string(9) "SCHEDULED"
      ["matchday"]=>
      int(1)
      ["stage"]=>
      string(14) "REGULAR_SEASON"
      ["group"]=>
      string(14) "Regular Season"
      ["lastUpdated"]=>
      string(20) "2018-08-01T18:02:07Z"
      ["homeTeam"]=>
      array(2) {
        ["id"]=>
        int(110)
        ["name"]=>
        string(8) "SS Lazio"
      }
      ["awayTeam"]=>
      array(2) {
        ["id"]=>
        int(113)
        ["name"]=>
        string(10) "SSC Napoli"
      }
      ["score"]=>
      array(6) {
        ["winner"]=>
        NULL
        ["duration"]=>
        string(7) "REGULAR"
        ["fullTime"]=>
        array(2) {
          ["homeTeam"]=>
          NULL
          ["awayTeam"]=>
          NULL
        }
        ["halfTime"]=>
        array(2) {
          ["homeTeam"]=>
          NULL
          ["awayTeam"]=>
          NULL
        }
        ["extraTime"]=>
        array(2) {
          ["homeTeam"]=>
          NULL
          ["awayTeam"]=>
          NULL
        }
        ["penalties"]=>
        array(2) {
          ["homeTeam"]=>
          NULL
          ["awayTeam"]=>
          NULL
        }
      }
      ["referees"]=>
      array(0) {
      }
    }
    [2]=>
    array(12) {
      ["id"]=>
      int(247790)
      ["season"]=>
      array(4) {
        ["id"]=>
        int(290)
        ["startDate"]=>
        string(10) "2018-08-18"
        ["endDate"]=>
        string(10) "2019-05-26"
        ["currentMatchday"]=>
        int(1)
      }
      ["utcDate"]=>
      string(20) "2018-08-19T16:00:00Z"
      ["status"]=>
      string(9) "SCHEDULED"
      ["matchday"]=>
      int(1)
      ["stage"]=>
      string(14) "REGULAR_SEASON"
      ["group"]=>
      string(14) "Regular Season"
      ["lastUpdated"]=>
      string(20) "2018-08-01T18:02:07Z"
      ["homeTeam"]=>
      array(2) {
        ["id"]=>
        int(586)
        ["name"]=>
        string(9) "Torino FC"
      }
      ["awayTeam"]=>
      array(2) {
        ["id"]=>
        int(100)
        ["name"]=>
        string(7) "AS Roma"
      }
      ["score"]=>
      array(6) {
        ["winner"]=>
        NULL
        ["duration"]=>
        string(7) "REGULAR"
        ["fullTime"]=>
        array(2) {
          ["homeTeam"]=>
          NULL
          ["awayTeam"]=>
          NULL
        }
        ["halfTime"]=>
        array(2) {
          ["homeTeam"]=>
          NULL
          ["awayTeam"]=>
          NULL
        }
        ["extraTime"]=>
        array(2) {
          ["homeTeam"]=>
          NULL
          ["awayTeam"]=>
          NULL
        }
        ["penalties"]=>
        array(2) {
          ["homeTeam"]=>
          NULL
          ["awayTeam"]=>
          NULL
        }
      }
      ["referees"]=>
      array(0) {
      }
    }


  • 답변 # 1

    간단한 변수를 하나 더 가져 와서 현재 라운드와 이전 라운드 값이 같은지 확인하십시오.

    아래와 같은 것

    $roundName = "";
    foreach($data['matches'] as $record){
        $matchday = $record['matchday'];
        if($roundName != $matchday){
           echo '<h4>Round'. $matchday  .'</h4><br>';
        }
        echo $record['homeTeam']['name'].'&nbsp;-&nbsp;'.$record['awayTeam']['name'].'<br>';
        $roundName = $record['matchday'];
    }
    
    

    다른 해결책은

    키를 라운드 이름으로 사용하여 하나의 다차원 배열을 만듭니다.

    같은 것

    $array['round1'][0] = 'team 1 - team 2';
    $array['round1'][1] = 'team 3 - team 5';
    $array['round2'][0] = 'team 1 - team 2';
    $array['round2'][1] = 'team 3 - team 5';
    ................
    ................
    ................
    ................
    $array['roundn'][n] = 'team 3 - team 5';
    
    

관련 자료

  • 이전 mysql - 왼쪽 조인을 사용할 때 고유 한 선택된 ID로 선택한 결과 제한
  • 다음 ios - 자동 레이아웃 제약 조건 첫 번째 항목과 두 번째 항목은 어떻게 작동합니까?