Notice: This page requires JavaScript to function properly.
Please enable JavaScript in your browser settings or update your browser.
Lære Sammenligning af Strenge | Interaktioner Mellem Datatyper
Datatyper i Python

bookSammenligning af Strenge

Strengsammenligninger i Python er som standard store- og småbogstavsfølsomme. Hvis brugerinput kan variere i brugen af store og små bogstaver eller indeholde ekstra mellemrum, bør normalisering foretages før sammenligning. En enkel og pålidelig metode er at fjerne unødvendige mellemrum og standardisere bogstavstørrelse før ligheds- eller præfiks-/suffixkontrol.

Store- og småbogstavsfølsomhed vs. ufølsomhed

Som standard er "Apple" == "apple" False. For at ignorere forskel i bogstavstørrelse, normaliser begge sider.

123
a = "Hello" b = "heLLo" print(a.lower() == b.lower()) # True
copy

casefold() er en stærkere, internationalt venlig variant af lower() og er et bedre standardvalg til sammenligninger uden hensyn til store og små bogstaver.

123
s1 = "straße" s2 = "STRASSE" print(s1.casefold() == s2.casefold()) # True
copy

Trim og sammenlign

Brugere tilføjer ofte mellemrum ved en fejl. Fjern indledende og afsluttende mellemrum før sammenligning.

123
raw = " admin " role = "ADMIN" print(raw.strip().casefold() == role.casefold()) # True
copy

Kontrol af præfiks og suffiks

Brug startswith og endswith. For store- og småbogstavs-uafhængige kontroller, normaliser først.

1234
fname = "Report_Final.PDF" print(fname.lower().endswith(".pdf")) # True prefix = "rep" print(fname.strip().casefold().startswith(prefix.casefold())) # True
copy

Konsistent normaliseringspipeline

Vælg en simpel, gentagelig rækkefølge:

  1. Fjern ydre mellemrum med .strip();
  2. Standardiser store/små bogstaver med .casefold() (eller .lower() hvis du foretrækker det);
  3. Brug derefter ==, in, startswith, endswith eller andre tjek.

1. Hvilken linje udfører et case-insensitive lighedstjek korrekt?

2. Givet s = " Hello ", hvilket udtryk returnerer True for et case-insensitive lighedstjek med "hello", hvor der ses bort fra omkringliggende mellemrum?

3. Hvilken påstand er mest præcis for robust sammenligning uden hensyn til store og små bogstaver?

question mark

Hvilken linje udfører et case-insensitive lighedstjek korrekt?

Select the correct answer

question mark

Givet s = " Hello ", hvilket udtryk returnerer True for et case-insensitive lighedstjek med "hello", hvor der ses bort fra omkringliggende mellemrum?

Select the correct answer

question mark

Hvilken påstand er mest præcis for robust sammenligning uden hensyn til store og små bogstaver?

Select the correct answer

Var alt klart?

Hvordan kan vi forbedre det?

Tak for dine kommentarer!

Sektion 4. Kapitel 2

Spørg AI

expand

Spørg AI

ChatGPT

Spørg om hvad som helst eller prøv et af de foreslåede spørgsmål for at starte vores chat

Suggested prompts:

Can you explain the difference between `lower()` and `casefold()` in more detail?

Are there any situations where `casefold()` might not be appropriate?

Can you show more examples of normalizing user input before comparison?

Awesome!

Completion rate improved to 5

bookSammenligning af Strenge

Stryg for at vise menuen

Strengsammenligninger i Python er som standard store- og småbogstavsfølsomme. Hvis brugerinput kan variere i brugen af store og små bogstaver eller indeholde ekstra mellemrum, bør normalisering foretages før sammenligning. En enkel og pålidelig metode er at fjerne unødvendige mellemrum og standardisere bogstavstørrelse før ligheds- eller præfiks-/suffixkontrol.

Store- og småbogstavsfølsomhed vs. ufølsomhed

Som standard er "Apple" == "apple" False. For at ignorere forskel i bogstavstørrelse, normaliser begge sider.

123
a = "Hello" b = "heLLo" print(a.lower() == b.lower()) # True
copy

casefold() er en stærkere, internationalt venlig variant af lower() og er et bedre standardvalg til sammenligninger uden hensyn til store og små bogstaver.

123
s1 = "straße" s2 = "STRASSE" print(s1.casefold() == s2.casefold()) # True
copy

Trim og sammenlign

Brugere tilføjer ofte mellemrum ved en fejl. Fjern indledende og afsluttende mellemrum før sammenligning.

123
raw = " admin " role = "ADMIN" print(raw.strip().casefold() == role.casefold()) # True
copy

Kontrol af præfiks og suffiks

Brug startswith og endswith. For store- og småbogstavs-uafhængige kontroller, normaliser først.

1234
fname = "Report_Final.PDF" print(fname.lower().endswith(".pdf")) # True prefix = "rep" print(fname.strip().casefold().startswith(prefix.casefold())) # True
copy

Konsistent normaliseringspipeline

Vælg en simpel, gentagelig rækkefølge:

  1. Fjern ydre mellemrum med .strip();
  2. Standardiser store/små bogstaver med .casefold() (eller .lower() hvis du foretrækker det);
  3. Brug derefter ==, in, startswith, endswith eller andre tjek.

1. Hvilken linje udfører et case-insensitive lighedstjek korrekt?

2. Givet s = " Hello ", hvilket udtryk returnerer True for et case-insensitive lighedstjek med "hello", hvor der ses bort fra omkringliggende mellemrum?

3. Hvilken påstand er mest præcis for robust sammenligning uden hensyn til store og små bogstaver?

question mark

Hvilken linje udfører et case-insensitive lighedstjek korrekt?

Select the correct answer

question mark

Givet s = " Hello ", hvilket udtryk returnerer True for et case-insensitive lighedstjek med "hello", hvor der ses bort fra omkringliggende mellemrum?

Select the correct answer

question mark

Hvilken påstand er mest præcis for robust sammenligning uden hensyn til store og små bogstaver?

Select the correct answer

Var alt klart?

Hvordan kan vi forbedre det?

Tak for dine kommentarer!

Sektion 4. Kapitel 2
some-alt