gpt4 book ai didi

parsing - ERLANG - 将列表拆分为子列表

转载 作者:行者123 更新时间:2023-12-01 09:38:38 27 4
gpt4 key购买 nike

您好,这是我在这里的第一篇文章,希望你们一切都好。所以我刚开始使用erlang,我遇到了一个我不知道如何解决的问题。

所以我收到了一个二进制文件,格式为

<<56, 23, 67, 34, 45, 78, 01, 54, 67, 87, 45, 53, 01, 34, 56, 78>>

我的目标是根据 01 将其拆分为子列表(或二进制,如果更有效)。

例如,上面应该看起来像:

<<56, 23, 67, 34, 45, 78>> <<54, 67, 87, 45, 53>> <<34, 56, 78>>

-或-

[[56, 23, 67, 34, 45, 78], [54, 67, 87, 45, 53], [34, 56, 78]]

01是分隔标签,不需要包含在最终输出中。

我已经尝试过这样的事情:(如果有更好的方法,请忽略)

parse1([]) -> [];
parse1(1) -> io:format("SOHSOHSOHSOHSOHSSOHSOHS");
parse1(Reply) -> parse1({Reply, []});
parse1({Reply, nxtParse}) ->
[H | T] = Reply,
case H of
_ when H > 1 ->
[H | nxtParse],
io:format("Reply 1 = ~p~n", [H]),
parse1({T, nxtParse});
_ when H == 1 ->
io:format("SOHSOHSOHSOHSOHSSOHSOHS");

[] ->
ok

end.

这根本不是很干净,根本不像 pro 写的。当有人提示我时,我肯定会“嗯”一下我的头。

我意识到肯定有不止一种解决方案,但最好的解决方案是什么。看来 ERL 有这么多 BIF 和做事的方法,我猜只是想找到我的方法。

感谢大家的帮助-B

最佳答案

随着 R14A,Erlang 现在包含一个 binary 处理此类任务的模块:

1> Bin = <<56, 23, 67, 34, 45, 78, 01, 54, 67, 87, 45, 53, 01, 34, 56, 78>>.
<<56,23,67,34,45,78,1,54,67,87,45,53,1,34,56,78>>
2> binary:split(Bin, <<01>>, [global]).
[<<56,23,67,34,45,78>>,<<"6CW-5">>,<<"\"8N">>]

请注意,虽然它看起来是错误的(<<"6CW-5">><<"\"8N">>),但底层表示是正确的,并且字符串是 VM 试图弄清楚如何打印出二进制文件。以原始格式输出时查看相同的调用:

3> io:format("~w~n", [binary:split(Bin, <<01>>, [global])]).
[<<56,23,67,34,45,78>>,<<54,67,87,45,53>>,<<34,56,78>>]
ok

关于parsing - ERLANG - 将列表拆分为子列表,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/3464207/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com