עבור לתוכן

פייתון|לולאות בתוך לולאה על מחרוזת.

Featured Replies

פורסם



def anti_vowel(text):
c="aeiouAEIOU"
for i in text:
for j in c:
if text[i] == c[j]:
text.remove(text[i])

return text

anti_vowel('Hey You')

יש לי בעיה הבנה של מה אני לא עושה נכון לגבי האיטרציה של כל אחת מהלולאות הנ"ל.

אנסה לפשט את צורת החשיבה שלי בכתיבת הקוד:

*הפונקציה מקבלת מחרוזת

*לולאה ראשונה רצה על כל תו במחרוזת כאשר הלולאה השנייה בודקת אם התו במחרוזת קלט שווה לאחד התווים ב c.

אני מתבלבל קצת בין C# לפייתון.

אם I ו J מאותחלים בריצה וc ו text מחרוזות,למה אני לא יכול לגשת אל התווים שלהם כרשימה text[i[

פורסם

הבעיה היא שכאשר אתה עובר על מחרוזת בלולאת for..in, הערך של של המשתנה (במקרה שלך i או j), לא מכיל את ה index עצמו של המחרוזת, אלא את ה- value (כלומר התו עצמו).

פורסם
  • מחבר

text]i[ לא מחזיר לי את הvalue כי i מחזיק את הvalue?.ז"א שאין תקינות לדבר הזה?.

זאת אומרת ש

for j in c

האתחול של j זה התו הראשון של המחרוזת c?.

פורסם

נכון :)

פורסם

זו לא הבעיה היחידה - באופן כללי אסור לשנות מבנה בזמן שאתה עובר עליו בלולאת for. בהרבה שפות תכנות זה יעיף שגיאה.

פורסם

אגב, בד"כ זה מאוד נדיר לראות nested loops בפייתון. כלומר זה אפשרי אבל לא מאוד פייתוני.

הנה דוגמה איך ניתן להשיג אותו אפקט בלי לולאות ישירות:


def anti_vowel(text):
return filter(lambda x: x.lower() not in 'aeiou', text)

פורסם

הפונקציה שלך מחזירה רשימה של תווים, לא מחרוזת. צריך לעשות join על התוצאה.

פורסם

לא נכון.

If iterable is a string or a tuple, the result also has that type; otherwise it is always a list.

פורסם

ואללה.

אני עשיתי את זה עם list comprehension שהחזיר לי רשימה, אז חשבתי שגם filter עובדת ככה.

ארכיון

דיון זה הועבר לארכיון ולא ניתן להוסיף בו תגובות חדשות.

דיונים חדשים