169 похожих чатов

Вот что получается в интерпрететоре, работает и результаты выгляд разумными,

но то как выглядит код мне не нравиться, а понять куда двигаться не очень могу, если кому не лень рекомендаций коментариев:
ghci> ur = Just "https://www.google.com/search?q=haskell"
ghci> res = handleResult ur
ghci> r2 = extractValue res
ghci> r3 <- extractFromIO r2
ghci> html = parseTree r3
ghci> ategs = title "a" html
ghci> ategsString = map (fmap B.unpack) ategs
ghci> fil = transformTree' filterHttpLinks ategsString
ghci> :t fil
fil :: [TagTree String]
длинна фил 22

42 ответов

116 просмотров

непонятно, каково назначение программы. просто набор функций. или это вы сделали библиотеку с инструментами для себя?

Fedor- Автор вопроса
Cheese Syrowiecki
непонятно, каково назначение программы. просто наб...

скорее пытаюсь по шагам тестировать, постепенно создавая функции которые дальше использовать в программе, но мне не нравиться самому то что получается

Fedor- Автор вопроса
Cheese Syrowiecki
тестировать на соответствие чему?

Ожидаемому результату, сейчас теги уже вполне разумные, в fil

Fedor
Ожидаемому результату, сейчас теги уже вполне разу...

ну я же прошу сформулировать, какой результат ты ожидаешь

Fedor- Автор вопроса
Cheese Syrowiecki
что именно не нравится?

вид, множество конверсий, есть подозрение что где то они лишние.

Fedor- Автор вопроса
Cheese Syrowiecki
ну я же прошу сформулировать, какой результат ты о...

извини, вчера он обсуждался, - ступил - я хочу выбрать теги А из результатов поиска, сейчас результат похож на осмысленный в переменной fil в интерпретаторе

Fedor
извини, вчера он обсуждался, - ступил - я хочу выб...

почему бы тогда не написать основную логику в файле, а не в репле?

Fedor- Автор вопроса
Cheese Syrowiecki
почему бы тогда не написать основную логику в файл...

так я собираю кусок, результатов и пишу функцию, которая это делает, и двигаюсь выше

вот тут кусок кода в ghci — это недописанная функция?

Fedor- Автор вопроса
Cheese Syrowiecki
вот тут кусок кода в ghci — это недописанная функц...

по сути будущая функция, кторая должна вернуть нужный fil

Fedor- Автор вопроса
Cheese Syrowiecki
о, да ты лиспер!

вот и мне кажеться что я что то не так делаю или не то....

Fedor
вот и мне кажеться что я что то не так делаю или н...

лично мне нравится в файле писать и в ghcid запускать автоматически

Fedor- Автор вопроса
Cheese Syrowiecki
не, всё правильно

Не уверен, просто не понимаю, как писать сверху...

Fedor- Автор вопроса
Cheese Syrowiecki
лично мне нравится в файле писать и в ghcid запуск...

кстати упоминался учебник какой посоветуете ?, а то мне попадался душкин, но он совсем не про то как пользоваться репл и тд

extractFromIO не делает ничего, можно убрать

Fedor
кстати упоминался учебник какой посоветуете ?, а т...

есть ещё советы на сайте https://ruhaskell.org/links

Fedor- Автор вопроса
Cheese Syrowiecki
сверху чего?

пишем функцию которая берет искомое и список ашрефов, и возращает номер или 0 например, потом пишем функцию формирующую этот список, например из дерева, и так далее вниз

Fedor
пишем функцию которая берет искомое и список ашреф...

а, top-down реализация? тут помогает undefined. пишешь сигнатуру, а как реализацию подставляешь undefined. пишешь тест и смотришь, где стреляет

Fedor- Автор вопроса
Cheese Syrowiecki
extractFromIO не делает ничего, можно убрать

ghci> html = parseTree r2 <interactive>:80:8: error: • No instance for (Text.StringLike.StringLike (IO B.ByteString)) arising from a use of ‘parseTree’ • In the expression: parseTree r2 In an equation for ‘html’: html = parseTree r2 это если не использовать строку r3 <- extractFromIO r2 что странно

Fedor- Автор вопроса
Cheese Syrowiecki
а, top-down реализация? тут помогает undefined. пи...

вот про это бы где поподробнее прочитать

Fedor
ghci> html = parseTree r2 <interactive>:80:8: err...

тут r2 — это действие, а не строка. надо сначала выполнить действие, чтобы появилась строка, которую можно парсить

Fedor
ghci> html = parseTree r2 <interactive>:80:8: err...

и назовите r2 понятно, например, getContent

Fedor
вот про это бы где поподробнее прочитать

про top-down проектирование и реализацию — книга HTDP (кстати, недавно вышел русский перевод под моей редакцией)

Fedor
вот про это бы где поподробнее прочитать

про top-down в Хаскеле — боюсь, нигде

Fedor- Автор вопроса
Fedor
ghci> html = parseTree r2 <interactive>:80:8: err...

стрелка влево как раз делает именно это — выполняет действие и даёт результат. и она уже есть в языке. строго говоря, это просто сахар для пользовательской функции (>>=), то есть не совсем встроено в язык, а вполне управляемо из прикладного кода

очень-очень рекомендую вместо return писать pure. смысл тот же самый (практически), но не будет лишних ошибочных ассоциаций

Fedor
понял, жаль...

изучите этот вопрос и напишите статью на ruhaskell.org!

Zygohistomorphic Prepromorphism🇺🇦
Що таке HTDP?

книга «Как проектировать программы» htdp.org

Cheese Syrowiecki
про top-down в Хаскеле — боюсь, нигде

Статья на хабре от Юриосити была

Zygohistomorphic Prepromorphism🇺🇦
Що таке HTDP?

имхо, лучший учебник программирования, причём не на каком-то языке (конкретно в этой книге используются учебные диалекты Рэкета, но это не важно), а в принципе. как декомпозировать задачу, как писать сигнатуру типа (даже в динамическом языке), документацию

Похожие вопросы

Обсуждают сегодня

Господа, а что сейчас вообще с рынком труда на делфи происходит? Какова ситуация?
Rꙮman Yankꙮvsky
29
А вообще, что может смущать в самой Julia - бы сказал, что нет единого стандартного подхода по многим моментам, поэтому многое выглядит как "хаки" и произвол. Короче говоря, с...
Viktor G.
2
30500 за редактор? )
Владимир
47
а через ESC-код ?
Alexey Kulakov
29
Чёт не понял, я ж правильной функцией воспользовался чтобы вывести отладочную информацию? но что-то она не ловится
notme
18
У меня есть функция где происходит это: write_bit(buffer, 1); write_bit(buffer, 0); write_bit(buffer, 1); write_bit(buffer, 1); write_bit(buffer, 1); w...
~
14
Добрый день! Скажите пожалуйста, а какие программы вы бы рекомендовали написать для того, чтобы научиться управлять памятью? Можно написать динамический массив, можно связный ...
Филипп
7
Недавно Google Project Zero нашёл багу в SQLite с помощью LLM, о чём достаточно было шумно в определённых интернетах, которые сопровождались рассказами, что скоро всех "ибешни...
Alex Sherbakov
5
Ребят в СИ можно реализовать ООП?
Николай
33
https://github.com/erlang/otp/blob/OTP-27.1/lib/kernel/src/logger_h_common.erl#L174 https://github.com/erlang/otp/blob/OTP-27.1/lib/kernel/src/logger_olp.erl#L76 15 лет назад...
Maksim Lapshin
20
Карта сайта