Machine Learning with Python
68K subscribers
1.27K photos
94 videos
161 files
927 links
Learn Machine Learning with hands-on Python tutorials, real-world code examples, and clear explanations for researchers and developers.
Download Telegram
In Python, loops are essential for repeating code efficiently: for loops iterate over known sequences (like lists or ranges) when you know the number of iterations, while loops run based on a condition until it's false (ideal for unknown iteration counts or sentinel values), and nested loops handle multi-dimensional data by embedding one inside another—use break/continue for control, and comprehensions for concise alternatives in interviews.

# For loop: Use for fixed iterations over iterables (e.g., processing lists)
fruits = ["apple", "banana", "cherry"]
for fruit in fruits: # Iterates each element
print(fruit) # Output: apple \n banana \n cherry

for i in range(3): # Numeric sequence (start=0, stop=3)
print(i) # Output: 0 \n 1 \n 2

# While loop: Use when iterations depend on a dynamic condition (e.g., user input, convergence)
count = 0
while count < 3: # Runs as long as condition is True
print(count)
count += 1 # Increment to avoid infinite loop! Output: 0 \n 1 \n 2

# Nested loops: Use for 2D data (e.g., matrices, grids); outer for rows, inner for columns
matrix = [[1, 2], [3, 4]]
for row in matrix: # Outer: each sublist
for num in row: # Inner: elements in row
print(num) # Output: 1 \n 2 \n 3 \n 4

# Control statements: break (exit loop), continue (skip iteration)
for i in range(5):
if i == 2:
continue # Skip 2
if i == 4:
break # Exit at 4
print(i) # Output: 0 \n 1 \n 3

# List comprehension: Concise for loop alternative (use for simple transformations/filtering)
squares = [x**2 for x in range(5) if x % 2 == 0] # Even squares
print(squares) # Output: [0, 4, 16]


#python #loops #forloop #whileloop #nestedloops #comprehensions #interviewtips #controlflow

https://t.iss.one/CodeProgrammer
Please open Telegram to view this post
VIEW IN TELEGRAM
3👏2
In Python, the re module handles regular expressions (regex) for pattern matching in strings—vital for text processing like validating emails, extracting data from logs, or cleaning user input in interviews; it's compiled for efficiency but can be complex, so start simple and test with tools like regex101.com.

import re

# Basic search: Find if pattern exists (returns Match object or None)
txt = "The rain in Spain"
match = re.search(r"Spain", txt) # r"" for raw string (avoids escaping issues)
if match:
print(match.group()) # Output: Spain (full match)
print(match.start(), match.end()) # Output: 12 17 (positions)

# findall: Extract all matches as list (non-overlapping)
txt = "The rain in Spain stays mainly in the plain"
emails = re.findall(r"\w+@\w+\.com", "Contact: [email protected] or [email protected]")
print(emails) # Output: ['[email protected]', '[email protected]']

# split: Divide string at matches (like str.split but with patterns)
words = re.split(r"\s+", "Hello world\twith spaces") # \s+ matches whitespace
print(words) # Output: ['Hello', 'world', 'with', 'spaces']

# sub: Replace matches (count limits replacements; use \1 for groups)
cleaned = re.sub(r"\d+", "***", "Phone: 123-456-7890 or 098-765-4321", count=1)
print(cleaned) # Output: Phone: *** or 098-765-4321 (first number replaced)

# Metacharacters basics:. (any char except \n), ^ (start), $ (end), * (0+), + (1+),? (0-1)
match = re.search(r"^The.*Spain$", txt) # ^ start, $ end,. any, * 0+ of previous
print(match.group() if match else "No match") # Output: The rain in Spain

# Character classes: \d (digit), \w (word char), [a-z] (range), [^0-9] (not digit)
nums = re.findall(r"\d+", "abc123def456") # \d+ one or more digits
print(nums) # Output: ['123', '456']

words_only = re.findall(r"\w+", "Hello123! World?") # \w+ word chars (alphanum + _)
print(words_only) # Output: ['Hello123', 'World']

# Groups: () capture parts; use for extraction or alternation
date = re.search(r"(\d{4})-(\d{2})-(\d{2})", "Event on 2023-10-27")
if date:
print(date.groups()) # Output: ('2023', '10', '27') (tuples of captures)
print(date.group(1)) # Output: 2023 (first group)

# Alternation: | for OR (e.g., cat|dog)
animals = re.findall(r"cat|dog", "I have a cat and a dog")
print(animals) # Output: ['cat', 'dog']

# Flags: re.IGNORECASE (case-insensitive), re.MULTILINE (^/$ per line)
text = "Spain\nin\nSpain"
matches = re.findall(r"^Spain", text, re.MULTILINE) # ^ matches start of each line
print(matches) # Output: ['Spain', 'Spain']

# Advanced: Greedy vs non-greedy (*? or +?) to match minimal
html = "<div><p>Text</p></div>"
content = re.search(r"<div>.*?</div>", html) #.*? non-greedy (stops at first </div>)
print(content.group()) # Output: <div><p>Text</p></div>

# Edge cases: Empty string, no match
print(re.search(r"a", "")) # Output: None
print(re.findall(r"\d", "no numbers")) # Output: []

# Compile for reuse (faster for multiple uses)
pattern = re.compile(r"\w+@\w+\.com")
email = pattern.search("[email protected]")
print(email.group() if email else "No email") # Output: [email protected]


Regex tips: Escape special chars with \ (e.g., . for literal dot); use raw strings (r""); test incrementally to avoid frustration—common pitfalls include forgetting anchors (^/$) or overusing.*. For performance, compile patterns; in interviews, explain your pattern step-by-step for clarity. #python #regex #re_module #patterns #textprocessing #interviews #stringmatching

😱 https://t.iss.one/CodeProgrammer
Please open Telegram to view this post
VIEW IN TELEGRAM
7