Convert Csv To Vcf Python May 2026

Convert Csv To Vcf Python May 2026

with open(csv_file, 'r', encoding=encoding) as infile: # Auto-detect delimiter if not specified if delimiter == ',': sample = infile.read(1024) infile.seek(0) sniffer = csv.Sniffer() if sniffer.has_header(sample): delimiter = sniffer.sniff(sample).delimiter reader = csv.DictReader(infile, delimiter=delimiter) with open(vcf_file, 'w', encoding='utf-8') as outfile: for row_num, row in enumerate(reader, 1): try: # Start vCard outfile.write('BEGIN:VCARD\n') outfile.write('VERSION:3.0\n') # Get name information full_name = find_column(row, column_mapping['full_name']) first_name = find_column(row, column_mapping['first_name']) last_name = find_column(row, column_mapping['last_name']) # Set full name if not directly provided if not full_name and (first_name or last_name): full_name = f"{first_name or ''} {last_name or ''}".strip() if full_name: outfile.write(f'FN:{sanitize_text(full_name)}\n') # Structured name (N: last;first;middle;prefix;suffix) if last_name or first_name: outfile.write(f'N:{sanitize_text(last_name or "")};{sanitize_text(first_name or "")};;;\n') # Phone numbers phone = find_column(row, column_mapping['phone']) if phone: outfile.write(f'TEL;TYPE=CELL:{sanitize_text(phone)}\n') phone_home = find_column(row, column_mapping['phone_home']) if phone_home: outfile.write(f'TEL;TYPE=HOME:{sanitize_text(phone_home)}\n') phone_work = find_column(row, column_mapping['phone_work']) if phone_work: outfile.write(f'TEL;TYPE=WORK:{sanitize_text(phone_work)}\n') # Email addresses email = find_column(row, column_mapping['email']) if email: outfile.write(f'EMAIL:{sanitize_text(email)}\n') email_home = find_column(row, column_mapping['email_home']) if email_home: outfile.write(f'EMAIL;TYPE=HOME:{sanitize_text(email_home)}\n') email_work = find_column(row, column_mapping['email_work']) if email_work: outfile.write(f'EMAIL;TYPE=WORK:{sanitize_text(email_work)}\n') # Address (simple version) address = find_column(row, column_mapping['address']) if address: outfile.write(f'ADR;TYPE=HOME:;;{sanitize_text(address)};;{sanitize_text(city or "")};{sanitize_text(state or "")};{sanitize_text(zip or "")};{sanitize_text(country or "")}\n') # Company and title company = find_column(row, column_mapping['company']) if company: outfile.write(f'ORG:{sanitize_text(company)}\n') title = find_column(row, column_mapping['title']) if title: outfile.write(f'TITLE:{sanitize_text(title)}\n') # Website website = find_column(row, column_mapping['website']) if website: outfile.write(f'URL:{sanitize_text(website)}\n') # Birthday birthday = find_column(row, column_mapping['birthday']) if birthday: # Try to format as YYYYMMDD if possible bday_clean = re.sub(r'[^0-9]', '', str(birthday)) if len(bday_clean) == 8: outfile.write(f'BDAY:{bday_clean}\n') else: outfile.write(f'BDAY:{birthday}\n') # Notes notes = find_column(row, column_mapping['notes']) if notes: outfile.write(f'NOTE:{sanitize_text(notes)}\n') # End vCard outfile.write('END:VCARD\n') outfile.write('\n') contacts_count += 1 except Exception as e: print(f"Error processing row {row_num}: {e}") continue

print(f"✅ Successfully converted {contacts_count} contacts") print(f"📁 Output saved to: {vcf_file}") convert csv to vcf python

def find_column(row, possible_names): """Find the first matching column from possible names""" for name in possible_names: if name in row and row[name]: return row[name] return None delimiter=delimiter) with open(vcf_file

Args: csv_file: Input CSV file path vcf_file: Output VCF file path encoding: File encoding (default: utf-8) delimiter: CSV delimiter (default: ',') """ encoding='utf-8') as outfile: for row_num

python csv_to_vcf.py contacts.csv output.vcf The script will handle various CSV formats, multiple phone numbers, email addresses, and properly format the vCard output for use with contact managers like Google Contacts, Apple Contacts, or Outlook.