JAVA记账---运用循环

运用循环进行记账。

方法1:用if语句

public class Text {

	public static void main(String[] args) {
		// TODO Auto-generated method stub

		//假设初始金额是10000元
		int money = 10000;
		//detail 用来记录收支情况。初始值为空字符串。
		String detail = "";
		//定义一个退出的标记,用于结束循环
		boolean exit = false;
		//创建一个扫描,用于扫描我们键盘输入的内容
		Scanner sc = new Scanner(System.in);
		
		//死循环,用于每次显示下列输出内容。
		while(exit==false)
		{
			System.out.println("------------家庭记账软件------------");
			System.out.println("			1.查看明细");
			System.out.println("			2.登记收入");
			System.out.println("			3.登记支出");
			System.out.println("			4.退出");
			System.out.print("			   请选择(1-4):");
			
			//输入选择的数字num。
			int num =sc.nextInt();
			
			if(num>4  || num<1 )
			{
				System.out.println("您输入的数字有误,请重新输入");
			}
			//当数字在1-4之间,进入循环
			while(num<4 && num>0)
			{
				if(num == 2)
				{
					System.out.print("本次收入金额:");
					int input = sc.nextInt();
					System.out.print("本次收入说明:");				
					String inpuse = sc.next();
					money+=input;
					detail+="收入"+"\t"+money+"\t"+input+"\t"+inpuse+"\n";
					System.out.println("登记完成");
					break;
				}
				if(num ==3)
				{
					System.out.print("本次支出金额:");
					int output = sc.nextInt();
					System.out.print("本次支出说明:");
					String outpuse = sc.next();
					money-=output;
					detail+="支出"+"\t"+money+"\t"+output+"\t"+outpuse+"\n";
					System.out.println("登记完成");
					break;
				}
				
				if(num == 1)
				{
					System.out.println("------------当前收支明细记录------------");
					System.out.println("收支"+"\t"+"账户金额"+"\t"+"收支金额"+"\t"+"说明");
					System.out.println(detail);
					break;
				}
			}
			
			if(num == 4)
			{
				System.out.print("确认是否退出(Y/N):");
				String a = sc.next();
				if(a.equals("Y"))
				{
					exit=true;
				}else if(a.equals("N"))
				{
					exit=false;
				}else
					System.out.println("输入错误,请重新输入");
					
					
			}
		}
	}

}

方法2:用switch.....case

public class TextSwitch {

	public static void main(String[] args) {
		//假设初始金额是10000元
				int money = 10000;
				//detail 用来记录收支情况。初始值为空字符串。
				String detail = "";
				//定义一个退出的标记,用于结束循环
				boolean exit = false;
				//创建一个扫描,用于扫描我们键盘输入的内容
				Scanner sc = new Scanner(System.in);
				
				//死循环,用于每次显示下列输出内容。
				while(exit==false)
				{
					System.out.println("------------家庭记账软件------------");
					System.out.println("			1.查看明细");
					System.out.println("			2.登记收入");
					System.out.println("			3.登记支出");
					System.out.println("			4.退出");
					System.out.print("			   请选择(1-4):");
					
					//输入选择的数字num。
					int num =sc.nextInt();
					
					while(num>4  || num<1 )
					{
						System.out.println("您输入的数字有误,请重新输入");
						num = sc.nextInt();
					}
					switch(num) {
					case 1:
						System.out.println("================当前收支明细记录================");
						System.out.println("收支\t账户金额\t收支金额\t说明");
						System.out.println(detail);
						break;
					case 2:
						
						System.out.print("本次收入金额:");
						int input = sc.nextInt();
						while(input<=0)
						{
							System.out.println("收入金额必须为正整数,请重新输入:");
						    input = sc.nextInt();
						}
						sc.nextLine();//清空键盘缓存区
						System.out.print("本次收入说明:");				
						String inpuse = sc.next();
						//更新余额
						money+=input;
						detail+="收入\t"+money+"\t"+input+"\t"+inpuse+"\n";
						System.out.println("登记完成");
						break;
					case 3:
						System.out.print("本次支出金额:");
						int output = sc.nextInt();
						System.out.print("本次支出说明:");
						String outpuse = sc.next();
						money-=output;
						detail+="支出\t"+money+"\t"+output+"\t"+outpuse+"\n";
						System.out.println("登记完成");
						break;
					case 4:
						System.out.print("确认是否退出(Y/N):");
						String a = sc.next();
						
						//if(a.equalsIgnoreCase("Y"))  //忽略大小写
						if(a.equals("Y")  || a.equals("y"))
						{
							exit=true;
						}else if(a.equals("N") || a.equals("n"))
						{
							exit=false;
						}else
							System.out.println("输入错误,请重新输入");
						break;
					}
					
				}

	}

}

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
java语言写的android系统,用于个人账目管理,课程设计上写的欢迎下载 package moneymanager.moneymanager; import android.content.ContentValues; import android.content.Context; import android.database.Cursor; import android.database.SQLException; import android.database.sqlite.SQLiteDatabase; import android.database.sqlite.SQLiteOpenHelper; import android.util.Log; /* * * 데이터베이스를 관리하는 클래스입니다. * */ public class DBAdapter { private static final String TAG = "NotesDbAdapter"; private DatabaseHelper mDbHelper; private SQLiteDatabase mDb; // 데이터베이스이름과 테블이름들을 정의 private static final String DATABASE_NAME = "MoneyManagerDB"; private static final int DATABASE_VERSION = 2; private static final String DATABASE_SETTING_TABLE = "SettingTbl"; private static final String DATABASE_BADGET_TABLE = "BadgetTbl"; private static final String DATABASE_PAYMENT_TABLE = "PaymentTbl"; // 테블안의 항목들을 정의 public static final String KEY_SETTINGTBL_ID = "ID"; public static final String KEY_SETTINGTBL_NAME = "Name"; public static final String KEY_SETTINGTBL_VALUE = "Value"; public static final String KEY_BADGETTBL_ID = "ID"; public static final String KEY_BADGETTBL_ITEM = "Item"; public static final String KEY_BADGETTBL_MONEY = "Money"; public static final String KEY_PAYMENTTBL_ID = "ID"; public static final String KEY_PAYMENTTBL_BADGETID = "BadgetID"; public static final String KEY_PAYMENTTBL_OUTDATE = "OutDate"; public static final String KEY_PAYMENTTBL_MONEY = "Money"; public static final String KEY_PAYMENTTBL_NOTE = "Note"; private final Context mCtx; private static class DatabaseHelper extends SQLiteOpenHelper { DatabaseHelper(Context context) { super(context, DATABASE_NAME, null, DATABASE_VERSION); } @Override public void onCreate(SQLiteDatabase db) { String strCreateTbl; // SettingTbl생성 strCreateTbl = "CREATE TABLE " + DATABASE_SETTING_TABLE + " (" + KEY_SETTINGTBL_ID + " INTEGER PRIMARY KEY AUTOINCREMENT, " + KEY_SETTINGTBL_NAME + " TEXT NOT NULL, " + KEY_SETTINGTBL_VALUE + " TEXT NOT NULL);"; db.execSQL(strCreateTbl); // BadgetTbl생성 strCreateTbl = "CREATE TABLE " + DATABASE_BADGET_TABLE + " (" + KEY_BADGETTBL_ID + " INTEGER PRIMARY KEY AUTOINCREMENT, " + KEY_BADGETTBL_ITEM + " TEXT NOT NULL, " + KEY_BADGETTBL_MONEY + " INTEGER NOT NULL);"; db.execSQL(strCreateTbl); // PaymentTbl생성 strCreateTbl = "CREATE TABLE " + DATABASE_PAYMENT_TABLE + " (" + KEY_PAYMENTTBL_ID + " INTEGER PRIMARY KEY AUTOINCREMENT, " + KEY_PAYMENTTBL_BADGETID + " INTEGER NOT NULL, " + KEY_PAYMENTTBL_OUTDATE + " TEXT NOT NULL, " + KEY_PAYMENTTBL_MONEY + " INTEGER NOT NULL, " + KEY_PAYMENTTBL_NOTE + " TEXT);"; db.execSQL(strCreateTbl); } ......

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值