extract booking data

This commit is contained in:
Ruidy 2024-06-14 12:27:55 +02:00
parent 0db50b2268
commit f9066d3ecb
No known key found for this signature in database
GPG key ID: E00F51288CB857CC
2 changed files with 14 additions and 45 deletions

View file

@ -1 +0,0 @@
package server

View file

@ -37,28 +37,25 @@ func handleSync() echo.HandlerFunc {
} }
func parseBooking(jsonString string) (*booking.Booking, error) { func parseBooking(jsonString string) (*booking.Booking, error) {
//jsonString = `"{\"content\":\" Date d'arrivée ven.\u00a024\u00a0mai\u00a02024 Date de départ lun.\u00a027\u00a0mai\u00a02024 Durée de séjour\u00a0: 3 nuits Nombre de personnes\u00a0: \\n \\n Nombre d'hébergements \\n 1\\n Montant total € 186 Nom du client\u00a0: \\n Katrin Anschütz\\n \\n mq\\n \\n kansch.199923@guest.booking.com\\n Contactez vos clients\u00a0! Indiquez-leur l'heure à laquelle vous souhaitez les accueillir ou l'endroit où ils récupéreront leurs clés. Un simple appel suffit\u00a0: Afficher le numéro de téléphone Vous pouvez également leur envoyer un e-mail ou un message. Langue préférée \\n allemand\\n Canal\u00a0: Booking.com Code IATA/TIDS\u00a0: \\n PC029090\\n Numéro de réservation\u00a0: \\n 4489841169\\n Montant soumis à commission\u00a0: € 177 Reçu jeu.\u00a016\u00a0mai\u00a02024 Commission\u00a0: € 31,86 Bloc-notes (usage interne) Ajoutez une note ici Heure d'arrivée approximative\u00a0: Entre 16:00 et 17:00 \\n\\n Maison 1 Chambre (T2 - VillaFleurie au bourg du Gosier)\\n € 186 ven.\u00a024\u00a0mai\u00a02024 lun.\u00a027\u00a0mai\u00a02024 Nom du client \\n Katrin Anschütz\\n Occupation maximum 2 adultes, 2 enfants (3 personnes max.) Photo de l'hébergement Date Tarif Tarif par nuit \\n 24 - 25 mai\\n \\n Standard Rate\\n € 59\\n 25 - 26 mai\\n \\n Standard Rate\\n € 59\\n 26 - 27 mai\\n \\n Standard Rate\\n € 59Sous-total € 177\\n Taxe de séjour\\n € 1.50 par personne et par nuit € 9Tarif total de l'hébergement € 186 Le tarif comprend 8.9 % de TVA Conversation avec le client \\n Aucun message\\n \\n Les conversations avec vos clients apparaîtront ici.\\n Booking.com reçoit tous les messages écrits ici et les traite selon sa Charte de confidentialité et informations sur les cookies Conditions \"}"}`
var bookingInfo BookingInfo var bookingInfo BookingInfo
err := json.Unmarshal([]byte(jsonString), &bookingInfo) err := json.Unmarshal([]byte(jsonString), &bookingInfo)
if err != nil { if err != nil {
fmt.Println("Error unmarshalling JSON:", err) return nil, fmt.Errorf("Error unmarshalling JSON:", err)
return nil, err
} }
content := bookingInfo.Content
log.Info(extractData(content))
arrivalDate := extractDate(`Date de d'arrivée `, content) content := strings.ReplaceAll(strings.TrimSpace(bookingInfo.Content), "\u00a0", " ")
log.Info(arrivalDate)
arrivalDate := extractDate(`Date d'arrivée `, content)
departureDate := extractDate(`Date de départ `, content) departureDate := extractDate(`Date de départ `, content)
log.Info(departureDate)
stayLength := extractInt(`Durée de séjour : (\d+) nuits`, content) stayLength := extractInt(`Durée de séjour : (\d+) nuits`, content)
totalAmount := extractFloat(`Montant total € (\d+)`, content) totalAmount := extractFloat(`Montant total € (\d+)`, content)
customerName := extractString(`Nom du client : \\n\s*(\S.+)\\n`, content) customerName := extractString(`Nom du client : \n\s+([\w\s]+)`, content)
customerName = strings.SplitN(customerName, "\n", 2)[0]
customerEmail := extractString(`[\w\.\-]+@[\w\.\-]+\.\w+`, content)
customerNumber := extractInt(`Nombre de personnes : \s*\n\s*(\d+)`, content)
commissionAmount := extractFloat(`Commission : € (\d+,\d+)`, content) commissionAmount := extractFloat(`Commission : € (\d+,\d+)`, content)
item := extractString(`Maison 1 Chambre \((T2|T3) -`, content) item := extractString(`Maison 1 Chambre \((T2|T3) -`, content)
standardRate := extractFloat(`Standard Rate\\n\s*€ (\d+)`, content) standardRate := extractFloat(`Standard Rate\n\s+€ (\d+)`, content)
taxesAmount := extractFloat(`Taxe de séjour\\n\s*€ (\d+,\d+)`, content)
result := map[string]any{ result := map[string]any{
"from": formatDate(arrivalDate), "from": formatDate(arrivalDate),
@ -66,10 +63,11 @@ func parseBooking(jsonString string) (*booking.Booking, error) {
"stay_length": stayLength, "stay_length": stayLength,
"total_amount": totalAmount, "total_amount": totalAmount,
"customer_name": customerName, "customer_name": customerName,
"email": customerEmail,
"customer_number": customerNumber,
"commission_amount": commissionAmount, "commission_amount": commissionAmount,
"item": item, "item": item,
"price": standardRate, "price": standardRate,
"taxes_amount": taxesAmount,
} }
jsonResult, err := json.MarshalIndent(result, "", " ") jsonResult, err := json.MarshalIndent(result, "", " ")
@ -88,9 +86,8 @@ func parseBooking(jsonString string) (*booking.Booking, error) {
} }
func extractDate(pattern, content string) string { func extractDate(pattern, content string) string {
cleanedInput := strings.ReplaceAll(content, "\u00a0", " ")
re := regexp.MustCompile(pattern + `\w+\.\s*\d{1,2}\s\w+\.\s\d{4}`) re := regexp.MustCompile(pattern + `\w+\.\s*\d{1,2}\s\w+\.\s\d{4}`)
dateMatch := re.FindString(cleanedInput) dateMatch := re.FindString(content)
if dateMatch == "" { if dateMatch == "" {
fmt.Println("date not found") fmt.Println("date not found")
@ -133,13 +130,13 @@ func extractString(pattern, content string) string {
if len(match) > 1 { if len(match) > 1 {
return strings.TrimSpace(match[1]) return strings.TrimSpace(match[1])
} }
return "" return strings.TrimSpace(match[0])
} }
func formatDate(date string) string { func formatDate(date string) string {
months := map[string]string{ months := map[string]string{
"janv.": "01", "fév": "02", "mar": "03", "avr": "04", "janv.": "01", "fév": "02", "mar": "03", "avr": "04",
"mai": "05", "jun": "06", "jul": "07", "aoû": "08", "mai": "05", "jun": "06", "juil.": "07", "aoû": "08",
"sep": "09", "oct": "10", "nov": "11", "déc": "12", "sep": "09", "oct": "10", "nov": "11", "déc": "12",
} }
re := regexp.MustCompile(`(\d+)\s([^\s]+)\s(\d{4})`) re := regexp.MustCompile(`(\d+)\s([^\s]+)\s(\d{4})`)
@ -152,30 +149,3 @@ func formatDate(date string) string {
} }
return "" return ""
} }
func extractData(content string) (string, string, string, string, string, string, string, string, string) {
// Define regex patterns for each field
arrivalDatePattern := regexp.MustCompile(`Date d'arrivée ven\\u00a0(\d{2}\\u00a0mai\\u00a020\d{2})`)
departureDatePattern := regexp.MustCompile(`Date de départ lun\\u00a0(\d{2}\\u00a0mai\\u00a020\d{2})`)
commissionPattern := regexp.MustCompile(`Commission\\u00a0: € (\d{2},\d{2})`)
customerNamePattern := regexp.MustCompile(`Nom du client\\u00a0: \\n\s+([\w\s]+)\\n`)
itemNamePattern := regexp.MustCompile(`Maison 1 Chambre $begin:math:text$([^)]+)$end:math:text$`)
itemPricePattern := regexp.MustCompile(`Tarif total de l'hébergement € (\d{3})`)
lengthOfStayPattern := regexp.MustCompile(`Durée de séjour\\u00a0: (\d{1}) nuits`)
amountOfTaxesPattern := regexp.MustCompile(`Taxe de séjour\\n\\u00a0€ (\d\.\d{2})`)
totalPricePattern := regexp.MustCompile(`Montant total € (\d{3})`)
// Extract data using regex
arrivalDate := arrivalDatePattern.FindStringSubmatch(content)
departureDate := departureDatePattern.FindStringSubmatch(content)
commission := commissionPattern.FindStringSubmatch(content)
customerName := customerNamePattern.FindStringSubmatch(content)
itemName := itemNamePattern.FindStringSubmatch(content)
itemPrice := itemPricePattern.FindStringSubmatch(content)
lengthOfStay := lengthOfStayPattern.FindStringSubmatch(content)
amountOfTaxes := amountOfTaxesPattern.FindStringSubmatch(content)
totalPrice := totalPricePattern.FindStringSubmatch(content)
// Return extracted data
return arrivalDate[1], departureDate[1], commission[1], customerName[1], itemName[1], itemPrice[1], lengthOfStay[1], amountOfTaxes[1], totalPrice[1]
}