Hàm int fscanf(FILE *stream, const char *format,…) trong Thư viện C chuẩn đọc input đã được định dạng từ một Stream.
Khai báo hàm fscanf() trong C
Dưới đây là phần khai báo cho hàm fscanf() trong C:
int fscanf(FILE *stream, const char *format, ...)
Tham số
stream − Đây là con trỏ tới một đối tượng FILE mà nhận diện Stream.
format − Đây là chuỗi mà chứa một hoặc nhiều mục sau: ký tự Whitespace, ký tự Non-whitespace và Format specifier. Một format specifier sẽ là dạng [=%[*][width][modifiers]type=], được giải thích như sau:
Tham số | Miêu tả |
---|---|
* | Đây là một dấu hoa thị bắt đầu (tùy ý) để chỉ rằng dữ liệu là được đọc từ Stream nhưng bị bỏ qua, ví dụ: nó không được lưu trữ trong tham số tương ứng |
width | Xác định số ký tự tối đa được đọc trong hoạt động đọc hiện tại |
modifiers | Xác định một kích cỡ khác với int (trong trường hợp d, I và n), unsigned int (trong trường hợp o,u và x) hoặc float (trong trường hợp e, f và g) cho dữ liệu được trỏ bởi tham số bổ sung tương ứng: h cho short int (cho d, i và n), hoặc unsigned short int (cho o, u và x); l cho long int (cho d, i và n), hoặc unsigned long int (cho o, u và x), hoặc double (cho e, f và g); L cho long double (cho e, f và g) |
type | Một ký tự xác định kiểu dữ liệu được đọc và cách nó được mong đợi được đọc. Bạn theo dõi bảng tiếp theo |
Type specifier cho hàm fscanf
Kiểu | Input | Kiểu tham số |
---|---|---|
c | Ký tự đơn: Đọc ký tự kế tiếp. Nếu một độ rộng khác 1 được xác định, thì hàm này đọc độ rộng các ký tự và lưu trữ chúng trong các vị trí liên tiếp nhau của mảng đã được truyền như là tham số. Không có ký tự null nào được phụ thêm vào cuối | char * |
d | Số nguyên hệ thập phân: Số này tùy ý được đặt trước bởi một dấu + hoặc – | int * |
e, E, f, g, G | Số thực dấu chấm động: Số thập phân chứa một dấu thập phân, được đặt trước tùy ý bởi một dấu + hoặc – và được theo sau tùy ý bởi ký tự e hoặc E và một số thập phân. Hai ví dụ hợp lệ là -732.103 và 7.12e4 | float * |
o | Số nguyên hệ bát phân | int * |
s | Chuỗi ký tự. Nó sẽ đọc các ký tự liên tiếp nhau tới khi tìm thấy một whitespace (có thể là blank, newline (dòng mới) và tab) | char * |
u | Số nguyên hệ thập phân không dấu | unsigned int * |
x, X | Số nguyên hệ thập lục phân | int * |
Các tham số bổ sung — Phụ thuộc vào chuỗi định dạng format, hàm này có thể có một dãy tham số bổ sung, mỗi tham số chứa một giá trị để được chèn thay cho mỗi %-tag được xác định trong tham số format, nếu có. Số tham số này nên cùng số lượng với số %-tags mà mong chờ một giá trị.
Trả về giá trị
Hàm này trả về số mục đầu vào được kết nối và gán thành công hoặc 0 nếu kết nối thất bại.
Ví dụ
Chương trình C sau minh họa cách sử dụng của hàm fscanf() trong C:
#include <stdio.h> #include <stdlib.h> int main() { char str1[10], str2[10], str3[10]; int year; FILE * fp; fp = fopen ("baitapc.txt", "w+"); fputs("Toi sinh nam 2016", fp); rewind(fp); fscanf(fp, "%s %s %s %d", str1, str2, str3, &year); printf("Doc chuoi 1: |%s|\n", str1 ); printf("Doc chuoi 2: |%s|\n", str2 ); printf("Doc chuoi 3: |%s|\n", str3 ); printf("Doc so nguyen: |%d|\n", year ); fclose(fp); return(0); }
Biên dịch và chạy chương trình C trên sẽ cho kết quả:
19 Th3 2021
19 Th3 2021
19 Th3 2021
19 Th3 2021
18 Th3 2021
19 Th3 2021