---
title: วิธีใช้ Power Query ดึงข้อมูล EMS Tracking จากไปรษณีย์ไทย ผ่าน Web API
url: https://www.thepexcel.com/power-query-ems-tracking-api/
type: post
date: 2022-09-10
updated: 2025-12-22
author: Sira Ekabut
categories: [Power Query]
tags: [power query, m code, api, Json.Document, Json.FromValue, Web.Contents]
---

# วิธีใช้ Power Query ดึงข้อมูล EMS Tracking จากไปรษณีย์ไทย ผ่าน Web API

ก่อนหน้านี้ผมได้เคยเขียนบทความวิธีใช้ Power Query ดึงข้อมูลจาก Web API ไปแล้ว 3 ตอน ถ้าใครยังไม่เคยเข้าไปอ่านก็สามารถเข้าไปอ่านดูก่อนได้นะครับ (ไม่อ่านก็ยังสามารถทำตามในบทความนี้ได้อยู่)

 
- [https://www.thepexcel.com/power-query-web-api-1/](https://www.thepexcel.com/power-query-web-api-1/)
- [https://www.thepexcel.com/power-query-web-api-2/](https://www.thepexcel.com/power-query-web-api-2/)
- [https://www.thepexcel.com/power-query-web-api-3/](https://www.thepexcel.com/power-query-web-api-3/)

 

ซึ่งบทความในวันนี้เนื้อหาจะคล้ายกับตอนที่ 2 ของเดิมมากๆ คือเป็น Web API แบบ Post แต่จะเป็น**กรณีตัวอย่างการใช้กับ EMS Tracking ของไปรษณีย์ไทยโดยเฉพาะ** ซึ่งหลายๆ คนน่าจะอยากใช้งานอยู่ ซึ่งวิธีทำนี้จะใช้ใน Excel หรือ Power BI ก็ได้นะครับ (พอดีมีลูกค้าที่เรียน Power BI กับผมถามมา เลยเอามาเขียนเป็นบทความเผื่อเพื่อนๆ คนอื่นด้วยเลยดีกว่า)

 

เพื่อไม่ให้เสียเวลา เรามาเริ่มดูขั้นตอนกันเลยละกัน

 

## สมัครสมาชิกแล้วเอา Token มาก่อน

 

ขั้นตอนแรกที่จำเป็นเลยคือเข้าไปในเว็บ [https://track.thailandpost.co.th/](https://track.thailandpost.co.th/) จากนั้นสมัครสมาชิกแล้วเข้าสู่ระบบให้เรียบร้อย (ขอไม่ลงรายละเอียดวิธีสมัครนะ)

 

จากนั้นให้เข้า[หน้า Dashboard](https://track.thailandpost.co.th/dashboard) ในส่วนของ <>สำหรับนักพัฒนา แล้วกด Create Token จากนั้น Copy Token ปัจจุบันออกมาซะ

 ![1](https://www.thepexcel.com/wp-content/uploads/2022/09/ems-api-001-1024x514.png) 

## ศึกษาคู่มือซักหน่อย

 

ผมเองก็ดูข้อมูล[ตามที่บอกในคู่มือ ในส่วนของ API REST](https://track.thailandpost.co.th/developerGuide) แล้วก็ทำตามได้ดังนี้ (คู่มือมีจุดที่เขียนแล้วสับสนตรง Token ให้ดูตัวอย่างผมแทนได้)

 

## GetToken สำหรับการรับส่งข้อมูล

 

โดย Token รับส่งข้อมูลนี้เป้นคนละตัวกับ Token จากการสมัครสมาชิกนะ… และจะมีการกำหนดวันหมดอายุ 1 เดือน

 

ให้เรา Get Data from Web แบบ Advanced แล้วใส่ดังนี้

 
- **URL Parts** : https://trackapi.thailandpost.co.th/post/api/v1/authenticate/token
- **HTTP Request Header**
    - **Authorization** : คำว่า Token ตามด้วยเว้นวรรค 1 ที ตามด้วย Token ในหน้าสมาชิก
    - **Content-Type** : application/json

 ![2](https://www.thepexcel.com/wp-content/uploads/2022/09/ems-api-002.png) 

จากนั้นกด ok แล้วกด Connect

 

มันก็จะทำการเข้าสู่ Power Query Editor **แล้วได้ผลลัพธ์มาเป็น Token รับส่งข้อมูล ** **ซึ่งจะยาวกว่า Token ในหน้าสมาชิกมากๆ** ให้เรา Copy เก็บเอาไว้ใช้ได้ **(Token รับส่งข้อมูลหมดอายุใน 1 เดือน)**

 ![3](https://www.thepexcel.com/wp-content/uploads/2022/09/ems-api-003-1024x379.png) 

พอเราได้ Token รับส่งข้อมูลแล้ว คราวนี้เราถึงสามารถทำการค้นหาตามพวกรหัส EMS ได้ซักที

 

## สร้าง Query ดึงข้อมูลจากรหัส Tracking

 

ให้เราสร้าง Blank Query (Get Data -> From Other Source -> Blank Query) ขึ้นมาแล้วเปลี่ยน Code ใน Advanced Editor ให้เป็นดังนี้

 

```
let

    BarCodeList={"EDXXXXXXXX","RLXXXXXXXX","EDXXXXXXXX"}, //List เก็บรหัส Track
    DataToken="xxxxxxx",  //Token รับส่งข้อมูลยาวๆ 
    MyRecord=[status="all",language="TH",barcode=BarCodeList], //Record ที่จะ Post เข้า API

    Source = Json.Document(Web.Contents("https://trackapi.thailandpost.co.th/post/api/v1/track", 
    [
        Headers=
            [
            Authorization="Token "&DataToken,
            #"Content-Type"="application/json"
            ],
        Content=Json.FromValue(MyRecord)                  
    ] 

    ))
in
    Source
```

 

จากนั้นเปลี่ยนสิ่งที่ระบุใน BarCodeList และ DataToken ตามต้องการ เช่น

 ![4](https://www.thepexcel.com/wp-content/uploads/2022/09/ems-api-004.png) 

จากนั้นพอ Run Query จะได้ดังนี้ แสดงว่าสำเร็จ

 ![5](https://www.thepexcel.com/wp-content/uploads/2022/09/ems-api-005-1024x156.png) 

## ดูข้อมูลที่ Response กลับมา

 

จากนั้นเราก็กดเข้าไปใน Record ที่ response กลับมา 1 ที แล้วกด Record ที่ items อีกที แล้วค่อยกด Convert เป็น Table

 ![6](https://www.thepexcel.com/wp-content/uploads/2022/09/ems-api-007-fix.png) 

จากนั้นให้ Expand List ออกมาเป็นหลายๆแถว

 ![7](https://www.thepexcel.com/wp-content/uploads/2022/09/ems-api-008-fix.png) 

จากนั้นค่อย Expand Record ออกมาโดยเลือกเอาเฉพาะคอลัมน์ที่ต้องการได้เลย

 ![8](https://www.thepexcel.com/wp-content/uploads/2022/09/ems-api-009-fix-1024x614.png) 

แล้วเราก็จะได้ Data ที่ต้องการแบบละเอียดทุกขั้นตอนเลย เย้!

 ![9](https://www.thepexcel.com/wp-content/uploads/2022/09/ems-api-010-1024x263.png) 

## ทำยังไงให้เพิ่ม List รหัสง่ายๆ

 

ที่นี้ถ้าอยากให้ Dynamic มากขึ้น แทนที่เราจะพิมพ์ List ของรหัส EMS ที่ต้องการ Track เข้าไปเอง เราก็ดึง List นั้นมาจาก Table ของ Excel ได้ เช่น ผมสร้าง Table ชื่อ TrackTable แล้วมีคอลัมน์ TrackNumber เอาไว้ (เอาจริงๆ จะเป็น Data Source อะไรก็ได้อ่ะนะ)

 ![10](https://www.thepexcel.com/wp-content/uploads/2022/09/ems-api-011-1024x398.png) 

จากนั้น Get Data เข้า Power Query ซะ

 

จากนั้นคลิ๊กขวาในคอลัมน์ที่ต้องการแล้ว DrillDown เราก็จะได้ List แล้ว

 ![11](https://www.thepexcel.com/wp-content/uploads/2022/09/ems-api-012.png) 

เนี่ยได้ List แล้ว ซึ่ง List นี้ชื่อว่า TrackTable

 ![12](https://www.thepexcel.com/wp-content/uploads/2022/09/ems-api-013.png) 

จากนั้นเราก็แค่เอา TrackTable ไปใส่ใน Code เดิมของเรา ก็จบ ง่ายขึ้นอีกเยอะ!!

 

```
let

    BarCodeList=TrackTable, //List เก็บรหัส Track
    DataToken="xxxxxxx",  //Token รับส่งข้อมูลยาวๆ 
    MyRecord=[status="all",language="TH",barcode=BarCodeList], //Record ที่จะ Post เข้า API

    Source = Json.Document(Web.Contents("https://trackapi.thailandpost.co.th/post/api/v1/track", 
    [
        Headers=
            [
            Authorization="Token "&DataToken,
            #"Content-Type"="application/json"
            ],
        Content=Json.FromValue(MyRecord)                  
    ] 

    ))
in
    Source
```

 

เนี่ย ทุกอย่างยังทำงานได้เหมือนเดิม **แต่เจ๋งกว่าเดิมตรงแก้รหัสที่จะ Track ได้ง่ายเลย!!**

 ![13](https://www.thepexcel.com/wp-content/uploads/2022/09/ems-api-014-1024x263.png) 

และนี่คือผลลัพธ์ที่เราได้ครับ แจ่มมากๆ

 ![14](https://www.thepexcel.com/wp-content/uploads/2022/09/ems-api-000-1024x255.png) 

**ข้อควรระวัง ที่เขียนไว้ในระบบ คือ** สามารถใช้งาน API ได้สูงสุด 1,000 หมายเลขต่อการ Post 1 ครั้ง โดยสามารถใช้งานได้ 15 ครั้ง ต่อ 3 วินาที กรณีมีการใช้งานเกิน 15 ครั้ง ต่อ 3 วินาที ระบบจะทำการปิดกั้นการใช้งานชั่วคราว เป็นระยะเวลา 30 วินาที

 

ดังนั้นอย่าส่งเยอะและถี่เกินไปนะครับ ^^

---

_Source: [https://www.thepexcel.com/power-query-ems-tracking-api/](https://www.thepexcel.com/power-query-ems-tracking-api/)_
