273 lines
12 KiB
Python
273 lines
12 KiB
Python
from datetime import datetime
|
|
import xlrd
|
|
import xmltodict
|
|
|
|
currency={ 'th_TH': {'name': 'บาท', 'partial': 'สตางค์', 'end': 'ถ้วน'}
|
|
, 'en_US': {'name': 'BAHT', 'partial': 'SATANG', 'end': 'ONLY'}
|
|
}
|
|
sym={
|
|
"en_US": {
|
|
"positive": "",
|
|
"negative": "MINUS",
|
|
"sep": " ",
|
|
"0": "ZERO",
|
|
"x": ["ONE", "TWO", "THREE", "FOUR", "FIVE", "SIX", "SEVEN", "EIGHT", "NINE"],
|
|
"1x": ["TEN", "ELEVEN", "TWELVE", "THIRTEEN", "FOURTEEN", "FIFTEEN", "SIXTEEN", "SEVENTEEN", "EIGHTEEN", "NINETEEN"],
|
|
"x0": ["TWENTY", "THIRTY", "FORTY", "FIFTY", "SIXTY", "SEVENTY", "EIGHTY", "NINETY"],
|
|
"100": "HUNDRED",
|
|
"1K": "THOUSAND",
|
|
"1M": "MILLION",
|
|
"and": "AND",
|
|
},
|
|
"th_TH": {
|
|
"positive": "",
|
|
"negative": "ลบ",
|
|
"sep": "",
|
|
"0": "ศูนย์",
|
|
"x": ["หนึ่ง","สอง","สาม","สี่","ห้า","หก","เจ็ด","แปด","เก้า"],
|
|
"x0": ["สิบ","ยี่สิบ","สามสิบ","สี่สิบ","ห้าสิบ","หกสิบ","เจ็ดสิบ","แปดสิบ","เก้าสิบ"],
|
|
"x1": "เอ็ด",
|
|
"100": "ร้อย",
|
|
"1K": "พัน",
|
|
"10K": "หมื่น",
|
|
"100K": "แสน",
|
|
"1M": "ล้าน",
|
|
"and": "",
|
|
}
|
|
}
|
|
|
|
DAYS={
|
|
'th_TH': ['จันทร์', 'อังคาร', 'พุธ', 'พฤหัสบดี', 'ศุกร์', 'เสาร์', 'อาทิตย์'],
|
|
'th_TH2': ['จันทร์', 'อังคาร', 'พุธ', 'พฤหัสบดี', 'ศุกร์', 'เสาร์', 'อาทิตย์'],
|
|
'en_US': ['Monday', 'Tuesday', 'Wednesday', 'Thursday', 'Friday', 'Saturday', 'Sunday']
|
|
}
|
|
|
|
MONTHS={
|
|
'th_TH': [None, 'มกราคม', 'กุมภาพันธ์', 'มีนาคม', 'เมษายน', 'พฤษภาคม', 'มิถุนายน', 'กรกฎาคม', 'สิงหาคม', 'กันยายน', 'ตุลาคม', 'พฤศจิกายน', 'ธันวาคม'],
|
|
'th_TH2': [None, 'ม.ค.', 'ก.พ.', 'มี.ค.', 'เม.ย.', 'พ.ค.', 'มิ.ย.', 'ก.ค.', 'ส.ค.', 'ก.ย.', 'ต.ค.', 'พ.ย.', 'ธ.ค.'],
|
|
'en_US': [None, 'January', 'February', 'March', 'April', 'May', 'June', 'July', 'August', 'September', 'October', 'November', 'December']
|
|
}
|
|
|
|
PATIENT_TYPE={
|
|
"sc":"ปกส.",
|
|
"uc":"UC.",
|
|
"others": "จ่ายเอง",
|
|
}
|
|
|
|
STAFF_TYPE={
|
|
'doctor': 'แพทย์',
|
|
'nurse': 'พยาบาล',
|
|
'staff': 'ทั่วไป',
|
|
}
|
|
|
|
TOPICS={
|
|
'topic1': {'name': 'จำนวนครั้งการทำ Hemodialysis', 'unit': 'ครั้ง'},
|
|
'topic2': {'name': 'จำนวนผู้ป่วยยกมาจากเดือน', 'unit': 'คน'},
|
|
'topic3': {'name': 'จำนวนผู้ป่วยรับใหม่เดือน', 'unit': 'คน'},
|
|
'topic4': {'name': 'จำนวนผู้ป่วยจำหน่ายเดือน', 'unit': 'คน'},
|
|
'topic5': {'name': 'จำนวนผู้ป่วยยกไปเดือน', 'unit': 'คน'},
|
|
'topic6': {'name': 'จำนวนผู้ป่วยเบิก ปกส.', 'unit': 'คน'},
|
|
'topic7': {'name': 'จำนวนผู้ป่วยเบิก สปกส.', 'unit': 'คน'},
|
|
'topic8': {'name': 'จำนวนผู้ป่วยจ่ายเอง', 'unit': 'คน'},
|
|
}
|
|
|
|
def _num2word(n,l="en_US"):
|
|
number=n
|
|
if number==0:
|
|
return sym[l]["0"] + ""
|
|
elif number<10:
|
|
return sym[l]["x"][number-1]
|
|
elif number<100:
|
|
if l=="en_US":
|
|
if number<20:
|
|
return sym[l]["1x"][number-10]
|
|
else:
|
|
return sym[l]["x0"][int(number/10-2)]+(number%10 and sym[l]["sep"]+_num2word(number%10,l) or "")
|
|
elif l=="th_TH":
|
|
return sym[l]["x0"][int(number/10-1)]+(number%10 and (number%10==1 and sym[l]["x1"] or sym[l]["x"][number%10-1]) or "")
|
|
elif number<1000:
|
|
return sym[l]["x"][int(number/100-1)]+sym[l]["sep"]+sym[l]["100"]+(number%100 and sym[l]["sep"]+_num2word(number%100,l) or "")
|
|
|
|
elif number<1000000:
|
|
if l=="en_US":
|
|
return _num2word(int(number/1000),l)+sym[l]["sep"]+sym[l]["1K"]+(number%1000 and sym[l]["sep"]+_num2word(number%1000,l) or "")
|
|
elif l=="th_TH":
|
|
if number<10000:
|
|
return sym[l]["x"][int(number/1000-1)]+sym[l]["1K"]+(number%1000 and _num2word(number%1000,l) or "")
|
|
elif number<100000:
|
|
return sym[l]["x"][int(number/10000-1)]+sym[l]["10K"]+(number%10000 and _num2word(number%10000,l) or "")
|
|
else:
|
|
return sym[l]["x"][int(number/100000-1)]+sym[l]["100K"]+(number%100000 and _num2word(number%100000,l) or "")
|
|
elif number<1000000000:
|
|
return _num2word(int(number/1000000),l)+sym[l]["sep"]+sym[l]["1M"]+sym[l]["sep"]+(number%1000000 and _num2word(number%1000000,l) or "")
|
|
else:
|
|
return "N/A"
|
|
|
|
def num2word(n,l="th_TH"):
|
|
'''
|
|
>>> num2word(-666, 'en_US')
|
|
'MINUS SIX HUNDRED SIXTY SIX BAHT ONLY'
|
|
|
|
>>> print num2word(-1024, 'th_TH')
|
|
ลบหนึ่งพันยี่สิบสี่บาทถ้วน
|
|
|
|
>>> num2word(42.00, 'en_US')
|
|
'FORTY TWO BAHT ONLY'
|
|
|
|
>>> print num2word(42.00, 'th_TH')
|
|
สี่สิบสองบาทถ้วน
|
|
|
|
>>> num2word(29348.23, 'en_US')
|
|
'TWENTY NINE THOUSAND THREE HUNDRED FORTY EIGHT BAHT AND TWENTY THREE SATANG'
|
|
|
|
>>> print num2word(29348.23, 'th_TH')
|
|
สองหมื่นเก้าพันสามร้อยสี่สิบแปดบาทยี่สิบสามสตางค์
|
|
|
|
>>> num2word(293812913.12, 'en_US')
|
|
'TWO HUNDRED NINETY THREE MILLION EIGHT HUNDRED TWELVE THOUSAND NINE HUNDRED THIRTEEN BAHT AND TWELVE SATANG'
|
|
|
|
>>> print num2word(293812913.12, 'th_TH')
|
|
สองร้อยเก้าสิบสามล้านแปดแสนหนึ่งหมื่นสองพันเก้าร้อยสิบสามบาทสิบสองสตางค์
|
|
|
|
>>> print num2word(0.0, 'th_TH')
|
|
ศูนย์บาทถ้วน
|
|
|
|
>>> print num2word(0.75, 'th_TH')
|
|
เจ็ดสิบห้าสตางค์
|
|
'''
|
|
|
|
base=0
|
|
end=0
|
|
number = n
|
|
print("number", number)
|
|
if type(n) == type(''):
|
|
number=float(n)
|
|
word = ''
|
|
if type(number) in (int, float):
|
|
sign = 'positive' if number >= 0 else 'negative'
|
|
number = abs(number)
|
|
number = ('%.2f'%number).split('.')
|
|
base = _num2word(int(number[0]),l=l) if int(number[0]) > 0 else 0
|
|
if int(number[1])!=0:
|
|
end = _num2word(int(number[1]),l=l)
|
|
if base != 0 and end == 0:
|
|
word = sym[l][sign] + sym[l]['sep'] + base + sym[l]['sep'] + currency[l]['name'] + sym[l]['sep'] + currency[l]['end']
|
|
if base != 0 and end != 0:
|
|
word = sym[l][sign] + sym[l]['sep'] + base + sym[l]['sep'] + currency[l]['name'] + sym[l]['sep'] + sym[l]['and'] + sym[l]['sep'] + end+sym[l]['sep'] + currency[l]['partial']
|
|
if base == 0 and end != 0:
|
|
word = sym[l][sign] + sym[l]['sep'] + sym[l]['and'] + sym[l]['sep'] + end+sym[l]['sep'] + currency[l]['partial']
|
|
if base == 0 and end == 0:
|
|
base = _num2word(0.00,l=l)
|
|
word = sym[l][sign] + sym[l]['sep'] + base + sym[l]['sep'] + currency[l]['name'] + sym[l]['sep'] + currency[l]['end']
|
|
return word.strip()
|
|
|
|
def read_excel(fpath=None,sheet_name="Sheet1",show_datetime=False):
|
|
data={}
|
|
if fpath:
|
|
suffix=fpath.split(".")[-1]
|
|
if suffix not in ('xls', 'xlsx'):
|
|
raise Exception("ERROR : please should file xls or xlsx")
|
|
wb=xlrd.open_workbook(fpath)
|
|
sheet=wb.sheet_by_name(sheet_name)
|
|
keys = [sheet.cell(0, col_index).value for col_index in range(sheet.ncols)]
|
|
data=[]
|
|
for row_index in range(1, sheet.nrows):
|
|
d={}
|
|
for col_index in range(sheet.ncols):
|
|
ctype=sheet.cell(row_index,col_index).ctype
|
|
if ctype==3:
|
|
value=sheet.cell(row_index, col_index).value
|
|
year, month, day, hour, minute, second = xlrd.xldate_as_tuple(value,wb.datemode)
|
|
value=datetime(year, month, day, hour, minute,second)
|
|
if show_datetime:
|
|
value=value.strftime("%Y-%m-%d %H:%M:%S")
|
|
else:
|
|
value=value.strftime("%Y-%m-%d")
|
|
else:
|
|
value=sheet.cell(row_index, col_index).value
|
|
d.update({(keys[col_index] or "").lower():value})
|
|
data.append(d)
|
|
return data
|
|
|
|
def read_xml(fpath=None,node="HDBills"):
|
|
root_name="STMSTM"
|
|
child_name=node
|
|
data={}
|
|
if not child_name:
|
|
return data
|
|
if fpath:
|
|
suffix=fpath.split(".")[-1]
|
|
if suffix not in ('xml'):
|
|
raise Exception("ERROR : please should file xml")
|
|
data=xmltodict.parse(open(fpath,"r").read())
|
|
root=data.get(root_name)
|
|
lines=[]
|
|
if root:
|
|
child=root.get(child_name)
|
|
if not child:
|
|
return {}
|
|
for k, v in child.items():
|
|
collections=v
|
|
for collection in collections:
|
|
if isinstance(collection,dict):
|
|
line={}
|
|
for i, j in collection.items():
|
|
key=(i or "").lower()
|
|
line[key]=j
|
|
lines.append(line)
|
|
return lines
|
|
|
|
def date2thai(date, format='%(BY)s-%(m)s-%(d)s', lang='th_TH'):
|
|
'''
|
|
>>> date2thai('2011-12-31', lang='th_TH')
|
|
'2554-12-31'
|
|
>>> date2thai('2011-12-31', format='%(Td)s %(d)s %(Tm)s, %(By)s', lang='en_US')
|
|
'Saturday 31 December, 54'
|
|
>>> print date2thai('2011-12-31', format='%(Td)s %(d)s %(Tm)s, %(By)s', lang='th_TH')
|
|
เสาร์ 31 ธันวาคม, 54
|
|
>>> date2thai('2000-06-08', lang='th_TH')
|
|
'2543-06-08'
|
|
>>> date2thai('2000-06-08', format='%(Td)s %(d)s %(Tm)s, %(By)s', lang='en_US')
|
|
'Thursday 08 June, 43'
|
|
>>> print date2thai('2000-06-08', format='%(Td)s %(d)s %(Tm)s, %(By)s', lang='th_TH')
|
|
พฤหัสบดี 08 มิถุนายน, 43
|
|
'''
|
|
|
|
if not date or not date.count('-') == 2:
|
|
return ''
|
|
|
|
year, month, day = date.split('-')
|
|
|
|
#dow = DateTime.Date(int(year), int(month), int(day)).day_of_week
|
|
dow = datetime(int(year),int(month),int(day)).weekday()
|
|
return format % { 'BY': int(year) + 543
|
|
, 'By': int(year[2:]) + 43
|
|
, 'Tm': MONTHS[lang][int(month)]
|
|
, 'Td': DAYS[lang][dow]
|
|
, 'm': month
|
|
, 'd': int(day) # XXX remove zero
|
|
}
|
|
|
|
def htmlcolor(r, g, b):
|
|
#ex: htmlcolor(250,0,0) => '#fa0000'
|
|
def _chkarg(a):
|
|
if isinstance(a, int): # clamp to range 0--255
|
|
if a < 0:
|
|
a = 0
|
|
elif a > 255:
|
|
a = 255
|
|
elif isinstance(a, float): # clamp to range 0.0--1.0 and convert to integer 0--255
|
|
if a < 0.0:
|
|
a = 0
|
|
elif a > 1.0:
|
|
a = 255
|
|
else:
|
|
a = int(round(a*255))
|
|
else:
|
|
raise ValueError('Arguments must be integers or floats.')
|
|
return a
|
|
r = _chkarg(r)
|
|
g = _chkarg(g)
|
|
b = _chkarg(b)
|
|
return '#{:02x}{:02x}{:02x}'.format(r,g,b)
|