metaclass: (Default)
[personal profile] metaclass
Периодически возникает надобность делать алгоритмы, имитирующие мышление бухгалтера или воссоздающие информацию по ее некой производной, введенной руками в базу данных. Напрягает страшно.

Например: есть связанные проводки по обоим сторонам счета, связь между которыми находится в голове бухгалтера и иногда в базе данных. Задача - заменить две связанные проводки на одну, исключив этот самый счет. В лучшем случае - соответствие проводок 1-1, 1-N. В самом мрачном случае - M-N и заодно еще часть проводок сторнирована, а часть положена противоположно другим. Мрачность усугубляется тем, что проводки лежат в старой системе, из которой я гружу данные в свою, и которая не накладывает никаких ограничений на смысл прокладываемых проводок.

Еще был гротеск, когда такие проводки пришлось сворачивать не имея информации о связи вообще. Только зная что она есть, т.е. внутренний счет закрывается под ноль. Решил подбором сумм с обоих сторон - т.е. все связи все таки были вида 1-N или N-1. Алгоритм подбирал для каждой суммы подходящие слагаемые с другой стороны.

Докатился еще до использования проводок вида Д(-) -> Д(+) или К(-) -> К(+), т.е. проводки только по дебету или только по кредиту. Такие проводки хороши тем, что не увеличивают обороты, если использовать их для внутренних перемещений внутри счета, и для некоторых случаев гораздо красивее отражают хозяйственную операцию, нежели обычные проводки.

Date: 2006-06-13 08:33 pm (UTC)
From: [identity profile] metaclass.livejournal.com
Вероятность большая. Но по сравнению с остальным бардаком это мелочи, да и алгоритм почти что одноразового применения. Я его сделал, чтобы проверить - будет там 1-N или нет.
А о смысле там и говорить не приходится - 75 проводок по обоим сторонам счета без малейших намеков "что это такое"

Date: 2006-06-13 08:38 pm (UTC)
From: [identity profile] kkirsanov.livejournal.com
А...
Просто уменя было, - БД по внутренностям компов.

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

Profile

metaclass: (Default)
metaclass

April 2017

S M T W T F S
      1
2345678
9101112 131415
16171819202122
23242526272829
30      

Most Popular Tags

Style Credit

Expand Cut Tags

No cut tags
Page generated Sep. 25th, 2025 12:48 pm
Powered by Dreamwidth Studios