dhPossessive = strName1 + "а"
End Select
Else
' Склонение женской фамилии
Select Case Right(strName1, 1)
Case "о", "и", "б", "в", "г", "д", "ж", "з", "к", "л", _
"м", "н", "п", "р", "с", "т", "ф", "х", "ц", "ч", _
"ш", "щ", "ь"
dhPossessive = strName1
Case "я"
dhPossessive = Mid(strName1, 1, Len(strName1) – 2) & «ой»
Case Else
dhPossessive = Mid(strName1, 1, Len(strName1) – 1) & «ой»
End Select
End If
dhPossessive = dhPossessive & " "
End If
' Склонение имени в родительный падеж
If Len(strName2) > 0 Then
If fMan Then
' Склонение мужского имени
Select Case Right(strName2, 1)
Case "й", "ь"
dhPossessive = dhPossessive & Mid(strName2, _
1, Len(strName2) – 1) & "я"
Case Else
dhPossessive = dhPossessive & strName2 & "а"
End Select
Else
' Склонение женского имени
Select Case Right(strName2, 1)
Case "а"
Select Case Mid(strName2, Len(strName2) – 1, 1)
Case "и", "г"
dhPossessive = dhPossessive & Mid( _
strName2, 1, Len(strName2) – 1) & "и"
Case Else
dhPossessive = dhPossessive & Mid(strName2, _
1, Len(strName2) – 1) & "ы"
End Select
Case "я"
If Mid(strName2, Len(strName2) – 1, 1) = "и" Then
dhPossessive = dhPossessive & Mid(strName2, _
1, Len(strName2) – 1) & "и"
Else
dhPossessive = dhPossessive & Mid(strName2, _
1, Len(strName2) – 1) & "и"
End If
Case "ь"
dhPossessive = dhPossessive & Mid(strName2, _
1, Len(strName2) – 1) & "и"
Case Else
dhPossessive = dhPossessive & strName2
End Select
End If
dhPossessive = dhPossessive & " "
End If
' Склонение отчества в родительный падеж
If Len(strName3) > 0 Then
If fMan Then
dhPossessive = dhPossessive & strName3 & "а"
Else
dhPossessive = dhPossessive & Mid(strName3, 1, _
Len(strName3) – 1) & "ы"
End If
End If
End Function
Function dhDative(strName1 As String, strName2 As String, _
strName3 As String) As String
Dim fMan As Boolean
' Определяем, мужские ФИО или женские
fMan = (Right(strName3, 1) = "ч")
' Склонение фамилии в дательный падеж
If Len(strName1) > 0 Then
If fMan Then
' Склонение мужской фамилии
Select Case Right(strName1, 1)
Case "о", "и", "я", "а"
dhDative = strName1
Case "й"
dhDative = Mid(strName1, 1, Len(strName1) – 2) + «ому»
Case Else
dhDative = strName1 + "у"
End Select
Else
' Склонение женской фамилии
Select Case Right(strName1, 1)
Case "о", "и", "б", "в", "г", "д", "ж", "з", "к",
"л", _ "м", "н", "п", "р", "с", "т", "ф", "х", "ц", "ч", "ш", _
"щ", "ь"
dhDative = strName1
Case "я"
dhDative = Mid(strName1, 1, Len(strName1) – 2)
& «ой»
Case Else
dhDative = Mid(strName1, 1, Len(strName1) – 1)
& «ой»
End Select
End If
dhDative = dhDative & " "
End If
' Склонение имени в дательный падеж
If Len(strName2) > 0 Then
If fMan Then
'Склонение мужского имени
Select Case Right(strName2, 1)
Case "й", "ь"
dhDative = dhDative & Mid(strName2, 1, _
Len(strName2) – 1) & "ю"
Case Else
dhDative = dhDative & strName2 & "у"
End Select
Else
' Склонение женского имени
Select Case Right(strName2, 1)
Case "а", "я"
If Mid(strName2, Len(strName2) – 1, 1) = "и" Then
dhDative = dhDative & Mid(strName2, 1, _
Len(strName2) – 1) & "и"
Else
dhDative = dhDative & Mid(strName2, 1, _
Len(strName2) – 1) & "е"
End If
Case "ь"
dhDative = dhDative & Mid(strName2, 1, _