目次
ユーザー テーブル、ユーザー消費記録テーブル
ホームページ バックエンド開発 PHPチュートリアル 日次料金計算のコードロジック (php)

日次料金計算のコードロジック (php)

Jun 20, 2016 pm 12:45 PM

A、B、C という 3 人が一緒に住んでおり、食料品の購入など、彼らの毎日の出費を記録するための Web サイトを開発する必要があるとします。では、データテーブルはどのように設計すればよいのでしょうか?さらに、これらのデータは各人が支払わなければならない合計金額をどのように計算するのでしょうか?
以下は私のコードです:
//$aData の各配列は毎日の消費記録を表します、金額: その日の総費用、平均: 1 人当たりの費用、その他の表現 ユーザー名: 1/0/-1 支払者/支払う必要はありません/支払う必要がある人
$aData = [
['money' => 30, 'mean'=> 10, 'twl' => 1, 'xxx' = > -1, 'yyy' => -1],
['お金' => 5, 'twl' => 1, 'yyy' => 0],
$count = 0;
foreach($aData as $val){
$val as $k => $v){
if($k == 'money'){
$count += $val['money']; }elseif($k ! = '平均' && $k != 'ボス'){
$aList[$k][] = [
'out' => $val['money'] : 0, // 支払うお金を意味します
'in' = & gt & lt; Val ['mean']: 0, // 共有したいお金を意味します
'誰' = > $val['ボス'],
}
}
}

$aData = []; = > $v){
$in = $out = 0;
foreach($v as $key => $val){
$in += $val['in'];
$out += $val['out'];
}
$aData[$k] = [
'out' =>
'in' => ; $in,
];
}

結果は

誰が誰に支払ったのかはまだわかりません。アドバイスを求める




ディスカッション(解決策)に返信 Boss
はデータに表示されません。 アイデア:

ユーザー テーブル、ユーザー消費記録テーブル

どのアイテムがカウントされるかは、ユーザー消費テーブルのアイテムに基づいています。

user table

user_id
username
password

consumption table
id
user_id ユーザー ID
consumption_type 消費タイプ: 例: 電気代、食べ物の購入、車の乗車
金額
作成時間時間

実際に私が言いたいのは、どの要素を配列に追加してマークし、各人がお互いにいくら与えるべきかを計算するということです。誰に

これはどういう意味ですか?

これとほぼ同じです。

$aData = [ ['money' => 30, 'mean'=> 10, 'twl' => 1, 'xxx' => -1, 'yyy' => -1],   ['money' => 10, 'mean'=> 5, 'twl' => -1, 'xxx' => 1, 'yyy' => 0],];foreach($aData as $m) {  $u = array_diff_key($m, ['money' => 0, 'mean' => 0]);  arsort($u);  foreach($u as $k=>$v) {    if(!isset($r[$k])) $r[$k] = ['out' => 0, 'in' => 0, 'boss' => []];    if($v == 0) continue;    if($v == 1) {      $boss = $k;      $r[$k]['out'] += $m['money'];    }else {      $r[$k]['out'] += $m['mean'];      $r[$k]['boss'][] = $boss;      $r[$boss]['in'] += $m['mean'];    }  }}print_r($r);
ログイン後にコピー
$aData = [
Array(    [twl] => Array        (            [out] => 35            [in] => 20            [boss] => Array                (                    [0] => xxx                )        )    [yyy] => Array        (            [out] => 10            [in] => 0            [boss] => Array                (                    [0] => twl                )        )    [xxx] => Array        (            [out] => 20            [in] => 5            [boss] => Array                (                    [0] => twl                )        ))
ログイン後にコピー
['money' => 30, 'mean'=> 10, 'twl' とします。 => 1, 'xxx' => -1, 'yyy' => -1],

['お金' => 10, 'twl' => -1, 'xxx' => 1, 'yyy' => 1],

['mean'=> 5, 'twl' => 'xxx' => 1, 'yyy' => 0],
['money' => 10, 'twl' => ; 1, 'yyy' => -1],
['お金' => 10, 'twl' => 1, ' yyy' => -1]、
['money' => 10、'twl' => 1、'yyy' => ; -1],
];

また計算されたデータが正確ではないように感じます

一つずつ計算できます


そうですね、ありがとうございます。あなたのアイデアはとても役に立ちました。

このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホットな記事タグ

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

11ベストPHP URLショートナースクリプト(無料およびプレミアム) 11ベストPHP URLショートナースクリプト(無料およびプレミアム) Mar 03, 2025 am 10:49 AM

11ベストPHP URLショートナースクリプト(無料およびプレミアム)

Laravelでフラッシュセッションデータを使用します Laravelでフラッシュセッションデータを使用します Mar 12, 2025 pm 05:08 PM

Laravelでフラッシュセッションデータを使用します

LaravelのバックエンドでReactアプリを構築する:パート2、React LaravelのバックエンドでReactアプリを構築する:パート2、React Mar 04, 2025 am 09:33 AM

LaravelのバックエンドでReactアプリを構築する:パート2、React

Laravelテストでの簡略化されたHTTP応答のモッキング Laravelテストでの簡略化されたHTTP応答のモッキング Mar 12, 2025 pm 05:09 PM

Laravelテストでの簡略化されたHTTP応答のモッキング

PHPのカール:REST APIでPHPカール拡張機能を使用する方法 PHPのカール:REST APIでPHPカール拡張機能を使用する方法 Mar 14, 2025 am 11:42 AM

PHPのカール:REST APIでPHPカール拡張機能を使用する方法

Codecanyonで12の最高のPHPチャットスクリプト Codecanyonで12の最高のPHPチャットスクリプト Mar 13, 2025 pm 12:08 PM

Codecanyonで12の最高のPHPチャットスクリプト

2025 PHP状況調査の発表 2025 PHP状況調査の発表 Mar 03, 2025 pm 04:20 PM

2025 PHP状況調査の発表

Laravelの通知 Laravelの通知 Mar 04, 2025 am 09:22 AM

Laravelの通知

See all articles