string_similarity 2.1.1 copy "string_similarity: ^2.1.1" to clipboard
string_similarity: ^2.1.1 copied to clipboard

Finds degree of similarity between two strings, based on Dice's Coefficient, which is mostly better than Levenshtein distance.

example/string_similarity_example.dart

import 'package:string_similarity/string_similarity.dart';

void main() {
  // compare two strings
  final comparison = 'healed'.similarityTo(
      'sealed'); // or StringSimilarity.compareTwoStrings('healed', 'sealed')
  print(comparison); // → 0.8

  print(null.similarityTo(null)); // -> 1.0
  print('france'.similarityTo(null)); // -> 0.0

  // get the best match
  const mainString = 'Olive-green table for sale, in extremely good condition.';
  const targetStrings = <String?>[
    'For sale: green Subaru Impreza, 210,000 miles',
    'For sale: table in very good condition, olive green in colour.',
    'Wanted: mountain bike with at least 21 gears.',
    null
  ];
  final bestMatch = mainString.bestMatch(
      targetStrings); // or StringSimilarity.findBestMatch(mainString, targetStrings)
  print(
      bestMatch); // → 1:'For sale: table in very good condition, olive green in colour.'[0.6060606060606061]
  print(bestMatch
      .ratings); // → ['For sale: green Subaru Impreza, 210,000 miles'[0.2558139534883721], 'For sale: table in very good condition, olive green in colour.'[0.6060606060606061], 'Wanted: mountain bike with at least 21 gears.'[0.1411764705882353]]
}
copied to clipboard
120
likes
150
points
35.7k
downloads

Publisher

verified publisherjeremylandon.com

Weekly Downloads

2024.09.18 - 2025.04.02

Finds degree of similarity between two strings, based on Dice's Coefficient, which is mostly better than Levenshtein distance.

Repository (GitHub)

Documentation

API reference

License

MIT (license)

More

Packages that depend on string_similarity