如何在VB中用比较简单的语句编写一个计算星座的程序 求详细过程

如何在VB中用比较简单的语句编写一个计算星座的程序 求详细过程,第1张

简单是相对的,如果要求代码少而精,可能可读性与结构性就差,反之,要求可读性与结构性比较好,可能代码会增多。

就目前发展来说,由于计算机的速度和存储空间的极大提升,程序(算法)的可读性与结构性是主流要求。

我曾经说过,解决一个问题用一行代码和用一千行代码(例子举得比较极端),对计算机运行来说人们的感觉没有什么区别。

你的这个问题,有多种多样的解决方法,想当然的方法,会用到数组和比较复杂的If语句。

我现在用一个方法,请你看看是否觉得简单呢?

在窗体添加2个组合框,Combo1和Combo2,一个 按钮和一个文本框Text1:

代码如下:

Option Explicit

Private XZ As String

Private Sub Command1_Click()

Dim M As String

Dim D As String

Dim d1 As Date

Dim d2 As Date

Dim L As Integer

M = Combo1.Text

D = Combo2.Text

L = InStr(XZ, M)

If D <= Mid(XZ, L + 3, 3) Then

Text1.Text = "你的星座是:" &Mid(XZ, L - 3, 3)

Else

Text1.Text = "你的星座是:" &Mid(XZ, L + 6, 3)

End If

End Sub

Private Sub Form_Load()

Dim i As Integer

Combo1.Clear

For i = 1 To 12

If i <10 Then

Combo1.AddItem "0" &CStr(i) &"月"

Else

Combo1.AddItem CStr(i) &"月"

End If

Next i

Combo1.Text = Combo1.List(0)

Combo2.Clear

For i = 1 To 31

If i <10 Then

Combo2.AddItem "0" &CStr(i) &"日"

Else

Combo2.AddItem CStr(i) &"日"

End If

Next i

Combo2.Text = Combo2.List(0)

XZ = "魔羯座01月20日水瓶座02月19日双鱼座03月20日白羊座04月20日金牛座05月21日双子座06月21日巨蟹座" &_

"07月22日狮子座08月23日处女座09月23日天秤座10月23日天蝎座11月22日射手座12月21日魔羯座"

End Sub

我这个程序,没有用数组和复杂的If语句,但是,用了Instr()函数,可读性就相对差一些了。

同时2月份,还没有考虑闰年问题以及大月小月问题.

两个标签,两个Text

Public Function Constellation(mDate As Date) As String

'星座

Constellation = Mid("摩羯水瓶双鱼白羊金牛双子巨蟹狮子处女天秤天蝎射手摩羯", (Month(mDate) + IIf((Day(mDate) - (19 + Int(Mid("102123444533", Month(mDate), 1)))) >= 0, 0, -1)) * 2 + 1, 2) &"座"

End Function

Public Function GetCNum(d As Date) As Integer

Select Case Constellation(d)

Case "白羊座"

n = 0

Case "金牛座"

n = 1

Case "双子座"

n = 2

Case "巨蟹座"

n = 3

Case "狮子座"

n = 4

Case "处女座"

n = 5

Case "天秤座"

n = 6

Case "天蝎座"

n = 7

Case "射手座"

n = 8

Case "摩羯座"

n = 9

Case "水瓶座"

n = 10

Case "双鱼座"

n = 11

End Select

GetCNum = n

End Function

Private Sub Text1_KeyPress(KeyAscii As Integer)

Dim d As Date

If KeyAscii = 13 Then

d = Text1.Text

strConstellation = Constellation(d)

Select Case Constellation(d)

Case "白羊座"

s = "平时活力十足的你,今天却变得混身没劲!不想让感情只是三分钟热度,就仔细想想该如何经营。偶尔也要培养气质,去买本好书吧!今天没啥冲劲,不妨低调沉潜、伺机而动!"

Case "金牛座"

s = "会接触不少人,记得放开胸怀,别太闷了!睁大眼睛瞧,新对象或许就出现啰!一个轻松的聚会场合令你破费。工作:今天会和不少人开会,互动频繁。"

Case "双子座"

s = "无往不利、全力打拼!想让你安定下来,今天是个好时机!平时花钱很随兴的你,突然想作财务规划。今天会做一项重要决策,相信自己准没错!"

Case "巨蟹座"

s = "别老待在家里,今天是出外走走的好时机。和亲爱的他到户外踏青去!有场聚会将会让你破费。提升自己的竞争力,应接触些平时不懂的业务。"

Case "狮子座"

s = "收起尖锐的利爪,今天凡事好商量。强势的狮子成了温柔的小猫,只想依偎着心爱的他。会为家人购买一些小礼物!有人找你帮忙处理公务,你不好意思拒绝。"

Case "处女座"

s = "拓展生活圈,建立新关系的好时机。单身的人将感到特别地孤单,很期盼爱情降临。和朋友共同讨论合资的计划?工作: 要妥善处理合作案的细节? "

Case "天秤座"

s = "对事情能够屏除偏见,具有客观、冷静判断力的一天。对自己理念的坚持,让你在态度上也强势了起来。之前投资的都有获得回报的迹象。今天你让人感觉成熟稳重,可托付重任的样子!"

Case "天蝎座"

s = "顺路经过感兴趣的店,不妨进去看看。不要排斥相亲或是朋友介绍,也许会遇到不错的人选唷!适合出门逛街买些秋冬用品。初次相见的人特别值得注目,你从身上可学到不少东西。"

Case "射手座"

s = "年长的朋友可望对你提出有益的建言。今天是个适合向亲密朋友吐露心事的日子。为了讨好情人,不惜打种脸充胖子。要注意对长辈或年纪较长者,要比平常更客气一点的言词相待。"

Case "摩羯座"

s = "不论自己心情如何都要隐藏起来,多保持笑容才拉近与他人的关系。即使是亲密的人,还是要尊重对方的自尊心。真心诚意帮助别人,也是为自己开运。为了处理别人的事,自己的事都没做到一天就结束了。"

Case "水瓶座"

s = "是个不能一心二用的日子,顾得了东就顾不了西,力量宜集中在一件事物上。看人不能只看外表,小心有跌破眼镜的时候。一感到苗头不对,就要有修正计划的应变措施。心急的要求成果,反而越搞越乱,其实慢慢做的话,倒是还能蛮顺利就解决了。"

Case "双鱼座"

s = "陶醉于玩乐的气氛中,让你很high。热情参加朋友邀约的轻松聚会,会有意想不到的恋情发展。吃喝玩乐的开销颇大,小心控制。下班下课后的约会、休闲,可将压力一口气解消掉了。"

End Select

Label1.Caption = strConstellation &vbCrLf &s

End If

End Sub

Private Sub Text2_KeyPress(KeyAscii As Integer)

Dim d1 As Date, d2 As Date

If KeyAscii = 13 Then

arr = Array(Array(90, 64, 86, 22, 94, 65, 83, 44, 93, 25, 84, 46), _

Array(62, 91, 83, 41, 16, 94, 48, 85, 66, 93, 22, 76), _

Array(83, 42, 91, 67, 79, 20, 94, 63, 80, 39, 96, 24), _

Array(26, 83, 63, 94, 36, 82, 24, 96, 45, 84, 59, 94), _

Array(92, 22, 87, 43, 89, 63, 84, 30, 93, 63, 81, 44), _

Array(66, 93, 19, 86, 57, 96, 44, 82, 25, 94, 39, 83), _

Array(82, 47, 90, 17, 77, 46, 91, 64, 77, 21, 94, 64), _

Array(45, 87, 62, 92, 19, 76, 62, 94, 44, 58, 23, 97), _

Array(91, 65, 82, 47, 93, 23, 76, 35, 94, 64, 77, 23), _

Array(20, 96, 44, 78, 55, 97, 27, 82, 66, 96, 46, 78), _

Array(82, 21, 92, 59, 79, 44, 90, 22, 78, 43, 95, 66))

d1 = Text1.Text

d2 = Text2.Text

n1 = GetCNum(d1)

n2 = GetCNum(d2)

Label2.Caption = arr(n1)(n2)

End If

End Sub


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/yw/11143257.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-13
下一篇 2023-05-13

发表评论

登录后才能评论

评论列表(0条)

保存