Cách tìm kiếm dữ liệu trong file JSON bằng PHP

JSON, viết tắt của JavaScript Object Notation, là một định dạng nhẹ phổ biến để lưu trữ và trao đổi thông tin. Như cái tên gợi ý, ban đầu nó được bắt nguồn từ JavaScript, nhưng nó là một định dạng độc lập với ngôn ngữ để lưu trữ thông tin. Rất nhiều ngôn ngữ như PHP hiện triển khai các chức năng để đọc và tạo dữ liệu JSON

Hướng dẫn này sẽ dạy bạn cách đọc một tệp JSON và chuyển đổi nó thành một mảng trong PHP. Tìm hiểu cách phân tích cú pháp JSON bằng các hàm

    "email": "monty@something.com",
33 và
    "email": "monty@something.com",
34

Đọc JSON từ một tệp hoặc chuỗi trong PHP

Giả sử bạn có một tệp chứa thông tin ở định dạng JSON. Làm thế nào để bạn truy cập và lưu trữ nó trong PHP?

Trước tiên, bạn cần lấy dữ liệu từ tệp thành một biến bằng cách sử dụng

    "email": "monty@something.com",
35. Sau khi dữ liệu ở dạng chuỗi, bạn có thể gọi hàm
    "email": "monty@something.com",
36 để trích xuất thông tin từ chuỗi. Hãy nhớ rằng JSON chỉ cung cấp một cách để lưu trữ thông tin dưới dạng chuỗi bằng cách sử dụng một bộ quy tắc được xác định trước. Công việc của chúng tôi là giải mã đúng các chuỗi và lấy thông tin chúng tôi muốn

Hàm

    "email": "monty@something.com",
33 chấp nhận bốn tham số, nhưng bạn sẽ chỉ cần hai tham số đầu tiên trong hầu hết các trường hợp. Tham số đầu tiên chỉ định chuỗi mà bạn muốn giải mã. Tham số thứ hai xác định cách dữ liệu đã giải mã được trả về. Đặt nó thành
    "email": "monty@something.com",
38 sẽ trả về một mảng kết hợp và
    "email": "monty@something.com",
39 sẽ trả về các đối tượng. Đây là một ví dụ cơ bản. Chúng tôi có một tập tin được gọi là người. json với nội dung sau

1
{
2
    "email": "monty@something.com",
0
    "email": "monty@something.com",
1
    "email": "monty@something.com",
    "email": "monty@something.com",
3
    "email": "monty@something.com",
4
    "email": "monty@something.com",
5
    "email": "monty@something.com",
6

Chúng tôi có thể đọc thông tin từ tệp JSON này bằng cách sử dụng mã bên dưới

1
{
1
2
    "email": "monty@something.com",
1
{
4
    "email": "monty@something.com",
3
    "email": "monty@something.com",
5
{
7
{
8
{
9
2
0
2
1
2
2
2
3
2
4
2
5
2
6
2
7
2
8
2
9
    "email": "monty@something.com",
00
    "email": "monty@something.com",
01
    "email": "monty@something.com",
02
    "email": "monty@something.com",
03
    "email": "monty@something.com",
04
    "email": "monty@something.com",
05

Trong ví dụ trên,

    "email": "monty@something.com",
33 đã trả về một đối tượng vì tham số thứ hai được đặt thành
    "email": "monty@something.com",
39. Bạn có thể đặt thành
    "email": "monty@something.com",
38 để lấy lại dữ liệu dưới dạng mảng kết hợp

_______7

{
1
2
    "email": "monty@something.com",
1
{
4
    "email": "monty@something.com",
3
    "email": "monty@something.com",
5
    "email": "monty@something.com",
13
{
8
{
9
    "email": "monty@something.com",
16
2
1
2
2
2
3
2
4
    "email": "monty@something.com",
1
2
6
2
7
2
8
2
9
    "email": "monty@something.com",
6
    "email": "monty@something.com",
01
    "email": "monty@something.com",
02
    "email": "monty@something.com",
03
    "email": "monty@something.com",
04
    "email": "monty@something.com",
05

Bây giờ, chúng tôi sẽ giải mã JSON phức tạp hơn một chút và cố gắng lấy lại thông tin hữu ích từ nó

1
{
2
    "email": "monty@something.com",
0
    "email": "monty@something.com",
1
    "email": "monty@something.com",
    "email": "monty@something.com",
3
    "email": "monty@something.com",
39
    "email": "monty@something.com",
5
    "email": "monty@something.com",
41
{
8
    "email": "monty@something.com",
43
{
9
    "email": "monty@something.com",
45
2
1
    "email": "monty@something.com",
47
2
3
    "email": "monty@something.com",
49
2
4
    "email": "monty@something.com",
6

Mục tiêu của chúng tôi là lấy lại tất cả các quốc gia mà người đó đã đến thăm trong các năm khác nhau. Giá trị được trả về bởi

    "email": "monty@something.com",
43 thực sự sẽ là một mảng và chúng tôi sẽ lặp qua nó giống như các mảng thông thường để lấy dữ liệu của chúng tôi

1
{
1
2
    "email": "monty@something.com",
1
{
4
    "email": "monty@something.com",
3
    "email": "monty@something.com",
5
    "email": "monty@something.com",
13
{
8
{
9
    "email": "monty@something.com",
62
2
1
    "email": "monty@something.com",
64
2
3
2
4
    "email": "monty@something.com",
67
2
6
    "email": "monty@something.com",
69
2
8
{
01
2
9
{
03
    "email": "monty@something.com",
01
{
05
    "email": "monty@something.com",
03
{
07
    "email": "monty@something.com",
04
{
09_____1___1___150

Hãy xem qua một ví dụ cuối cùng về trích xuất thông tin từ tệp JSON. Đây là JSON mà từ đó chúng tôi sẽ trích xuất dữ liệu của mình

1
{
2
{
18
    "email": "monty@something.com",
1
{
20
    "email": "monty@something.com",
3
{
22
    "email": "monty@something.com",
5
{
24
{
8
{
26
{
9
{
28
2
1
{
30
2
3
{
32
2
4
{
34
2
6
{
36
2
8
{
30
2
9
{
40
    "email": "monty@something.com",
01
{
42
    "email": "monty@something.com",
03
{
36
    "email": "monty@something.com",
04
{
30
{
10
{
48
{
12
{
50
{
13
{
52
{
53
{
54
{
55
{
56
{
57
{
20
{
59
{
60
{
61
{
62
{
63
{
64
{
65
{
28
{
67
{
30
{
69
{
70
{
71
{
72
{
73
{
36
{
75
{
30
{
77
{
78
{
79
{
80
{
81
{
36
{
83
{
30
{
85
{
86
{
87
{
88
{
89
{
52
{
91
{
54
{
93
{
56
{
95
{
20
{
97
{
98
{
99
2
00
2
01
2
02
2
03
{
28
2
05
{
30_____

Lần này, chúng tôi có hai mảng lồng nhau trong dữ liệu JSON. Vì vậy, chúng tôi sẽ sử dụng hai vòng lặp lồng nhau để lấy các quốc gia được các khách hàng khác nhau ghé thăm

1
{
1
2
    "email": "monty@something.com",
1
{
4
    "email": "monty@something.com",
3
    "email": "monty@something.com",
5
    "email": "monty@something.com",
13
{
8
{
9
2
85
2
1
2
3
2
88
2
4
2
90
2
6
2
92
2
8
2
9
2
95
    "email": "monty@something.com",
01
2
97
    "email": "monty@something.com",
03
2
99
    "email": "monty@something.com",
04
{
01
{
10
{
12
{
03
{
13
    "email": "monty@something.com",
006
{
53
    "email": "monty@something.com",
008
{
55
    "email": "monty@something.com",
010
{
57
    "email": "monty@something.com",
012
{
59
    "email": "monty@something.com",
014
{
61
    "email": "monty@something.com",
016
{
63
    "email": "monty@something.com",
018
{
65
    "email": "monty@something.com",
012
{
67
    "email": "monty@something.com",
022
{
69
    "email": "monty@something.com",
024
{
71
    "email": "monty@something.com",
026
{
73
    "email": "monty@something.com",
012
{
75
{
05
{
77
{
07
{
79
{
09
{
81
{
11
{
83
{
85
    "email": "monty@something.com",
05

Bây giờ bạn sẽ có một ý tưởng sơ bộ về cách tiếp cận mà bạn nên thực hiện để đọc dữ liệu JSON từ một tệp tùy thuộc vào cách nó được tạo

Đọc dữ liệu JSON mà không cần biết trước các khóa

Cho đến nay chúng tôi đã đọc dữ liệu JSON nơi chúng tôi đã biết tất cả các khóa. Điều đó có thể không phải lúc nào cũng đúng. May mắn thay, chúng tôi vẫn có thể trích xuất thông tin hữu ích từ tệp khi chúng tôi đã lưu trữ nó dưới dạng một mảng kết hợp. Ví dụ sau đây sẽ làm sáng tỏ mọi thứ

1
{
2
    "email": "monty@something.com",
043
    "email": "monty@something.com",
1
{
22
    "email": "monty@something.com",
3
    "email": "monty@something.com",
047
    "email": "monty@something.com",
5
    "email": "monty@something.com",
049
{
8
    "email": "monty@something.com",
051
{
9
{
98
2
1
    "email": "monty@something.com",
055
2
3
    "email": "monty@something.com",
049
2
4
    "email": "monty@something.com",
059
2
6
{
60
2
8
    "email": "monty@something.com",
063
2
9
    "email": "monty@something.com",
049
    "email": "monty@something.com",
01
    "email": "monty@something.com",
067
    "email": "monty@something.com",
03
2
36
    "email": "monty@something.com",
04
    "email": "monty@something.com",
071
{
10
    "email": "monty@something.com",
073
{
12
    "email": "monty@something.com",
6

Các khóa trong JSON trên dường như là các chuỗi ngẫu nhiên mà chúng ta không thể đoán trước được. Tuy nhiên, khi chúng tôi chuyển đổi nó thành một mảng kết hợp, chúng tôi sẽ không còn cần phải biết chính xác các giá trị chính để lặp qua dữ liệu

1
{
1
2
    "email": "monty@something.com",
1
{
4
    "email": "monty@something.com",
3
    "email": "monty@something.com",
5
    "email": "monty@something.com",
13
{
8
{
9
    "email": "monty@something.com",
086
2
1
    "email": "monty@something.com",
088
2
3
    "email": "monty@something.com",
090
2
4
    "email": "monty@something.com",
092
2
6
    "email": "monty@something.com",
094
2
8
{
01
2
9
    "email": "monty@something.com",
01
{
03
    "email": "monty@something.com",
03
    "email": "monty@something.com",
101
    "email": "monty@something.com",
04
    "email": "monty@something.com",
103
{
10
    "email": "monty@something.com",
105
{
12
    "email": "monty@something.com",
107
{
13
{
11
{
53
{
55
    "email": "monty@something.com",
05

Tạo dữ liệu JSON trong PHP

Bạn cũng có thể biến dữ liệu của mình thành một chuỗi JSON được định dạng tốt trong PHP với sự trợ giúp của hàm

    "email": "monty@something.com",
44. Về cơ bản, nó chấp nhận ba tham số, nhưng bạn thường chỉ cần tham số đầu tiên, tôi. e. giá trị bạn muốn mã hóa trong hầu hết các tình huống

E

Bạn cũng có thể cần sử dụng một số cờ để nhận chuỗi JSON ở định dạng mong muốn. Ví dụ: bạn có thể sử dụng cờ

    "email": "monty@something.com",
45 để thêm khoảng trắng nhằm định dạng đúng chuỗi JSON. Tương tự, bạn có thể sử dụng cờ
    "email": "monty@something.com",
46 để đảm bảo các giá trị float luôn được lưu trữ dưới dạng float, ngay cả khi chúng tương đương với một số nguyên về độ lớn. Bạn có thể xem danh sách tất cả các cờ như vậy trong tài liệu chính thức

1
{
1
2
    "email": "monty@something.com",
1
    "email": "monty@something.com",
117
    "email": "monty@something.com",
3
    "email": "monty@something.com",
119
    "email": "monty@something.com",
5
    "email": "monty@something.com",
121
{
8
    "email": "monty@something.com",
123
{
9
    "email": "monty@something.com",
125
2
1
    "email": "monty@something.com",
127
2
3
    "email": "monty@something.com",
129
2
4
    "email": "monty@something.com",
131
2
6
2
8
    "email": "monty@something.com",
166
2
9
    "email": "monty@something.com",
01
{
03
    "email": "monty@something.com",
03
    "email": "monty@something.com",
171
    "email": "monty@something.com",
04
    "email": "monty@something.com",
173
{
10
    "email": "monty@something.com",
175
{
12
    "email": "monty@something.com",
177
{
13
    "email": "monty@something.com",
179
{
53
    "email": "monty@something.com",
181
{
55
    "email": "monty@something.com",
175
{
57
    "email": "monty@something.com",
185
{
59
    "email": "monty@something.com",
187
{
61
    "email": "monty@something.com",
181
{
63
    "email": "monty@something.com",
175
{
65
    "email": "monty@something.com",
193
{
67
    "email": "monty@something.com",
195
{
69
    "email": "monty@something.com",
181
{
71
    "email": "monty@something.com",
175
{
73
    "email": "monty@something.com",
01
{
75
    "email": "monty@something.com",
03
{
77
    "email": "monty@something.com",
05
{
79
    "email": "monty@something.com",
07
{
81
    "email": "monty@something.com",
09
{
83
{
11
{
85
{
87
    "email": "monty@something.com",
05

Xử lý lỗi trong quá trình mã hóa và giải mã

Định dạng JSON yêu cầu chúng tôi tuân theo một bộ quy tắc cụ thể để mã hóa và giải mã chuỗi phù hợp. Ví dụ: tên và giá trị phải được đặt trong dấu ngoặc kép và không được có dấu phẩy ở sau cặp tên-giá trị. Hàm

    "email": "monty@something.com",
47 có thể giúp bạn tìm ra loại lỗi mà bạn đang gặp phải để bạn có thể thực hiện các bước thích hợp. Đây là một ví dụ rất cơ bản

1
{
1
2
    "email": "monty@something.com",
1
    "email": "monty@something.com",
19
    "email": "monty@something.com",
3
    "email": "monty@something.com",
5
    "email": "monty@something.com",
22
{
8
    "email": "monty@something.com",
24
{
9
2
1
    "email": "monty@something.com",
27
2
3
    "email": "monty@something.com",
29
2
4
2
6
    "email": "monty@something.com",
05

Suy nghĩ cuối cùng

Trong hướng dẫn này, bạn đã học cách đọc dữ liệu JSON từ một tệp hoặc chuỗi trong PHP. Bạn cũng đã học cách chuyển đổi JSON đó thành một mảng và duyệt qua nó để trích xuất thông tin bạn muốn. Giờ đây, bạn có thể lấy thông tin từ JSON trong một tệp mà bạn không biết tất cả các khóa trong các cặp khóa-giá trị

Trong hai phần trước, chúng tôi đã đề cập đến cách bạn có thể xâu chuỗi dữ liệu dưới dạng JSON trong PHP và các lỗi bạn có thể gặp phải trong quá trình mã hóa và giải mã

Làm cách nào để lấy dữ liệu cụ thể từ tệp JSON trong PHP?

Để sử dụng hàm PHP file_get_contents[] chúng ta có thể đọc một tệp và truy xuất dữ liệu có trong tệp JSON. Sau khi lấy dữ liệu cần chuyển định dạng JSON sang định dạng mảng. Sau đó, với việc sử dụng câu lệnh lặp sẽ hiển thị dưới dạng bảng.

Bạn có thể truy vấn tệp JSON không?

Để truy vấn dữ liệu JSON, bạn có thể sử dụng T-SQL tiêu chuẩn . Nếu bạn phải tạo truy vấn hoặc báo cáo về dữ liệu JSON, bạn có thể dễ dàng chuyển đổi dữ liệu JSON thành hàng và cột bằng cách gọi hàm OPENJSON rowset. Để biết thêm thông tin, hãy xem Chuyển đổi dữ liệu JSON thành hàng và cột bằng OPENJSON [SQL Server].

Làm cách nào để in tệp JSON trong PHP?

PHP có một tùy chọn tên là “JSON_PRETTY_PRINT” được sử dụng với hàm json_encode[] để in dữ liệu JSON với căn chỉnh phù hợp và định dạng cụ thể . Tạo một tệp PHP với tập lệnh sau. Ở đây, tùy chọn JSON_PRETTY_PRINT đã được sử dụng để in dữ liệu JSON.

Chủ Đề