פורסם 2015 ביולי 2910 שנים def anti_vowel(text): c="aeiouAEIOU" for i in text: for j in c: if text[i] == c[j]: text.remove(text[i]) return textanti_vowel('Hey You')יש לי בעיה הבנה של מה אני לא עושה נכון לגבי האיטרציה של כל אחת מהלולאות הנ"ל.אנסה לפשט את צורת החשיבה שלי בכתיבת הקוד:*הפונקציה מקבלת מחרוזת*לולאה ראשונה רצה על כל תו במחרוזת כאשר הלולאה השנייה בודקת אם התו במחרוזת קלט שווה לאחד התווים ב c.אני מתבלבל קצת בין C# לפייתון.אם I ו J מאותחלים בריצה וc ו text מחרוזות,למה אני לא יכול לגשת אל התווים שלהם כרשימה text[i[
פורסם 2015 ביולי 2910 שנים הבעיה היא שכאשר אתה עובר על מחרוזת בלולאת for..in, הערך של של המשתנה (במקרה שלך i או j), לא מכיל את ה index עצמו של המחרוזת, אלא את ה- value (כלומר התו עצמו).
פורסם 2015 ביולי 2910 שנים מחבר text]i[ לא מחזיר לי את הvalue כי i מחזיק את הvalue?.ז"א שאין תקינות לדבר הזה?.זאת אומרת שfor j in c האתחול של j זה התו הראשון של המחרוזת c?.
פורסם 2015 ביולי 3010 שנים זו לא הבעיה היחידה - באופן כללי אסור לשנות מבנה בזמן שאתה עובר עליו בלולאת for. בהרבה שפות תכנות זה יעיף שגיאה.
פורסם 2015 באוגוסט 210 שנים אגב, בד"כ זה מאוד נדיר לראות nested loops בפייתון. כלומר זה אפשרי אבל לא מאוד פייתוני.הנה דוגמה איך ניתן להשיג אותו אפקט בלי לולאות ישירות:def anti_vowel(text): return filter(lambda x: x.lower() not in 'aeiou', text)
פורסם 2015 באוגוסט 210 שנים הפונקציה שלך מחזירה רשימה של תווים, לא מחרוזת. צריך לעשות join על התוצאה.
פורסם 2015 באוגוסט 210 שנים לא נכון. If iterable is a string or a tuple, the result also has that type; otherwise it is always a list.
פורסם 2015 באוגוסט 210 שנים ואללה.אני עשיתי את זה עם list comprehension שהחזיר לי רשימה, אז חשבתי שגם filter עובדת ככה.
ארכיון
דיון זה הועבר לארכיון ולא ניתן להוסיף בו תגובות חדשות.