Я ищу эквивалент sscanf()
в Python. Я хочу разобрать /proc/net/*
файла, в C я мог бы сделать что-то вроде этого:
int matches = sscanf(
buffer,
"%*d: %64[0-9A-Fa-f]:%X %64[0-9A-Fa-f]:%X %*X %*X:%*X %*X:%*X %*X %*d %*d %ld %*512s\n",
local_addr, &local_port, rem_addr, &rem_port, &inode);
Сначала я подумал использовать str.split
, но он разбивается не на заданные символы, а на строку sep
в целом:
>>> lines = open("/proc/net/dev").readlines()
>>> for l in lines[2:]:
>>> cols = l.split(string.whitespace + ":")
>>> print len(cols)
1
Который должен вернуть 17, как объяснено выше.
Есть ли Python, эквивалентный sscanf
(не RE), или функция разделения строк в стандартной библиотеке, которая разбивается на любой из диапазона символов, о котором я не знаю?