我需要读取任何行(从user_input)到原子列表,例如:
Example line, which contains any ASCII chars.
成:
[Example,'line,',which,contains,any,ASCII,'chars.']
到目前为止我得到了什么:
read_line_to_codes(user_input, Input),
atom_codes(IA,Input),
atomic_list_concat(AlistI,' ',IA).
但由于atom_codes,这只适用于单个单词.
read / 2也抱怨空格,有没有办法做到这一点?
哦,也许然后用逗号分成2d列表,附加点/感叹号/问号,例如:
[[Example,line],[which,contains,any,ASCII,chars],'.']
顺便说一句:那是SWI-prolog.
编辑:找到解决方案:
read_line_to_codes(user_input, Input),
string_to_atom(Input,IA),
atomic_list_concat(AlistI,' ',IA),
无法回答我自己的问题,因为我没有100个声誉: – /
最佳答案
input_to_atom_list(L) :-
read_line_to_codes(user_input, Input),
string_to_atom(Input,IA),
tail_not_mark(IA, R, T),
atomic_list_concat(XL, ',', R),
maplist(split_atom(' '), XL, S),
append(S, [T], L).
is_period(.).
is_period(?).
is_period(!).
split_atom(S, A, L) :- atomic_list_concat(XL, S, A), delete(XL, '', L).
%if tale is ? or ! or . then remove
%A:Atom, R:Removed, T:special mark
tail_not_mark(A, R, T) :- atom_concat(R, T, A), is_period(T),!.
tail_not_mark(A, R, '') :- A = R.
DEMO
1 ?- input_to_atom_list(L).
|: Example line, which contains any ASCII chars.
L = [['Example', line], [which, contains, any, 'ASCII', chars], '.'].