haritz

haritz

Member Since 2 Years Ago

Experience Points
2,560
Total
Experience

2,440 experience to go until the next level!

In case you were wondering, you earn Laracasts experience when you:

  • Complete a lesson — 100pts
  • Create a forum thread — 50pts
  • Reply to a thread — 10pts
  • Leave a reply that is liked — 50pts
  • Receive a "Best Reply" award — 500pts
Lessons Completed
17
Lessons
Completed
Best Reply Awards
0
Best Reply
Awards
  • start your engines Created with Sketch.

    Start Your Engines

    Earned once you have completed your first Laracasts lesson.

  • first-thousand Created with Sketch.

    First Thousand

    Earned once you have earned your first 1000 experience points.

  • 1-year Created with Sketch.

    One Year Member

    Earned when you have been with Laracasts for 1 year.

  • 2-years Created with Sketch.

    Two Year Member

    Earned when you have been with Laracasts for 2 years.

  • 3-years Created with Sketch.

    Three Year Member

    Earned when you have been with Laracasts for 3 years.

  • 4-years Created with Sketch.

    Four Year Member

    Earned when you have been with Laracasts for 4 years.

  • 5-years Created with Sketch.

    Five Year Member

    Earned when you have been with Laracasts for 5 years.

  • school-in-session Created with Sketch.

    School In Session

    Earned when at least one Laracasts series has been fully completed.

  • welcome-newcomer Created with Sketch.

    Welcome To The Community

    Earned after your first post on the Laracasts forum.

  • full-time-student Created with Sketch.

    Full Time Learner

    Earned once 100 Laracasts lessons have been completed.

  • pay-it-forward Created with Sketch.

    Pay It Forward

    Earned once you receive your first "Best Reply" award on the Laracasts forum.

  • subscriber Created with Sketch.

    Subscriber

    Earned if you are a paying Laracasts subscriber.

  • lifer Created with Sketch.

    Lifer

    Earned if you have a lifetime subscription to Laracasts.

  • evangelist Created with Sketch.

    Laracasts Evangelist

    Earned if you share a link to Laracasts on social media. Please email [email protected] with your username and post URL to be awarded this badge.

  • chatty-cathy Created with Sketch.

    Chatty Cathy

    Earned once you have achieved 500 forum replies.

  • lara-veteran Created with Sketch.

    Laracasts Veteran

    Earned once your experience points passes 100,000.

  • 10k-strong Created with Sketch.

    Ten Thousand Strong

    Earned once your experience points hits 10,000.

  • lara-master Created with Sketch.

    Laracasts Master

    Earned once 1000 Laracasts lessons have been completed.

  • laracasts-tutor Created with Sketch.

    Laracasts Tutor

    Earned once your "Best Reply" award count is 100 or more.

  • laracasts-sensei Created with Sketch.

    Laracasts Sensei

    Earned once your experience points passes 1 million.

  • top-50 Created with Sketch.

    Top 50

    Earned once your experience points ranks in the top 50 of all Laracasts users.

Level 1
2,560 XP
Jun
11
3 months ago
Activity icon

Replied to Scrapp Data Using Goutte

Thank you, will give a try.

Activity icon

Started a new Conversation Scrapp Data Using Goutte

Hello to everyone,

I am trying to scrap some data using Goutte. Currently, I have some methods where I can get TEAMS and PLAYERS.

Get Teams:

public function getTeams()
    {
        $client = new Client();

        $teams = $client->request('GET', 'https://lol.gamepedia.com/LEC/2020_Season/Summer_Season');

        $team = $teams->filter('.tournament-roster-header')->each(function ($node) {

            if (!Team::where('name', $node->text())->exists()) {
                $team = new Team();

                $team->name = $node->text();
                $team->short_name = $node->text();

                $team->save();
            }
        });

        $this->getHref();

        return redirect()->back()->with('message', 'Teams imported.');
    }

Get Players:

 public function getPlayers()
    {

        $client = new Client();

        $players = $client->request('GET', 'https://lol.gamepedia.com/LEC/2020_Season/Summer_Season/Team_Rosters');

        $players->filter('.catlink-players')->each(function ($node) {

            if (!Player::where('name', $node->text())->exists()) {
                $player = new Player();
                $player->name = $node->text();
                $player->save();
            }
        });

        $this->getPosition($players);

        return redirect()->back()->with('message', 'Players imported.');
    }

In the players table, I have a column with team_id. Each Player belongs to a team. From https://lol.gamepedia.com/LEC/2020_Season/Summer_Season/Team_Rosters site, I can get all players. In such web, you can see there is also a COACH. The problem I am facing now is that I do not know how I could get the name of the TEAM from that page since is not inside the table.

Currently, I am using this method to assing a team to each PLAYER. It works well, the problem is that I am using another page to check the players, I am using the team page. The problem is that in the roster I do not have the COACH, only the players. So in my method I exclude the COACH at the moment. The team player page has a / where you can see who the COACH is but its not in the same position in every team page.

public function getTeam()
    {
        $client = new Client();

        $teams_all = Team::all();

        foreach ($teams_all as $teamss) {
            $teams = $client->request('GET', 'https://lol.gamepedia.com' . $teamss->url);

            $teams->filter('.wikitable')->eq(0)->filter('tr')->each(function ($tr, $i) use ($teamss) {
                return $tr->filter('td')->eq(2)->each(function ($td, $i) use ($teamss) {
                    $team_id = Team::where('name', $teamss->name)->first();
                    if ($player = Player::where('name', trim($td->text()))->first()) {
                        if ($player->position != "Coach") {
                            $player = Player::where('name', trim($td->text()))->first();
                            $player->team_id = $team_id->id;
                            $player->save();
                        }
                    }
                });
            });
        }
    }

Is there any way I can use the page https://lol.gamepedia.com/LEC/2020_Season/Summer_Season/Team_Rosters and assing the team each player belongs too?

Thank you in advance.