因此,我正在try 为Swift上的String类创建一个替换函数,以符合它在Python上的工作方式(要替换的字符串,要替换的字符串,count to be replaced),我发现@rmaddy的这个扩展可以做到这一点,但是当我将它添加到我的XCode项目中时,我得到了错误:

在"Range"上引用初始值设定项"init(_:)"要求"String.Index"符合"Strideable"

//Developed by rmaddy @ https://stackoverflow.com/users/2303865/rmaddy

extension String {
    func replacingOccurrences<Target, Replacement>(of target: Target, with replacement: Replacement, count: Int, options: String.CompareOptions = [], range searchRange: Range<String.Index>? = nil) -> String where Target : StringProtocol, Replacement : StringProtocol {
        var matches = [Range<String.Index>]()
        
        //This is where I get the error
        var sRange = searchRange ?? Range(startIndex..<endIndex)
        
        
        while matches.count < count && !sRange.isEmpty {
            if let mRange = range(of: target, options: options, range: sRange, locale: nil) {
                matches.append(mRange)
                if options.contains(.backwards) {
                    sRange = Range(sRange.lowerBound..<mRange.lowerBound)
                } else {
                    sRange = Range(mRange.upperBound..<sRange.upperBound)
                }
            } else {
                break
            }
        }
        
        var res = self
        for range in matches.sorted(by: { $0.lowerBound > $1.lowerBound }) {
            res.replaceSubrange(range, with: replacement)
        }
        return res
    }
}

我已try 查看SWIFT文档,但找不到如何修复此问题,请帮助.

需要说明的是,我希望替换文本文件(作为脚本读取)中某个单词的多次出现,但不是全部.我没有使用查找和替换功能,因为我希望它是动态的,并且能够基于算法挑选替换单词.基本上,我是在做一件事,将"say"的出现改变为"exaved"和其他同义词.该项目是一个长文本文件的解释引擎,它在Python上运行很容易,但在Swift上重写它是非常有挑战性的.

感谢你们抽出时间来,各位.

推荐答案

通过这个扩展,您还可以改进其他一些方面.您应该扩展StringProtocol而不是字符串,使其成为泛型,并允许您将其与子字符串一起使用.另一个重要的变化是返回self而不是字符串.请注意,在扩展StringProtocol时,您需要将self限制为RangeReplaceableCollection以允许您使用replaceSubrange方法.我还会将区域设置添加到您的方法签名中,并对语法进行一些改进:

extension StringProtocol where Self: RangeReplaceableCollection {
    func replacingOccurrences<Target: StringProtocol, Replacement: StringProtocol>(
        of target: Target,
        with replacement: Replacement,
        count: Int,
        options: String.CompareOptions = [],
        range searchRange: Range<Index>? = nil,
        locale: Locale? = nil
    ) -> Self {
        var ranges: [Range<Index>] = []
        var searchRange = searchRange ?? startIndex..<endIndex
        while ranges.count < count && !searchRange.isEmpty {
            if let range = self.range(
                of: target,
                options: options,
                range: searchRange,
                locale: locale
            ) {
                ranges.append(range)
                searchRange = options.contains(.backwards) ?
                    searchRange.lowerBound..<range.lowerBound :
                    range.upperBound..<searchRange.upperBound
            } else {
                break
            }
        }
        var collection = self
        for range in ranges.sorted(using: KeyPathComparator(\.lowerBound, order: .reverse)) {
            collection.replaceSubrange(range, with: replacement)
        }
        return collection
    }
}

Swift相关问答推荐

WWDC Swift并发会话中的厨房服务示例令人困惑

显示第二个操作紧接在另一个操作后的工作表在SwiftUI中不起作用

当TextField变为空时,不会触发onChange

像WebSocket一样接收实时更新,但通过异步/等待或组合

如何使用变量 Select 哪个向量(?)在我的 struct 中密谋吗?

如何在 Vapor 中制作可选的查询过滤器

是否可以利用 Codable 从 Dictionary 初始化符合类型

子视图未在父视图 SwiftUI 中触发禁用状态更新

如何在 UITableView 中点击图片和标题

如何从数据中读取以空结尾的字符串?

Swift 有没有办法在不使用 switch 语句的情况下获取关联值?

Swift UI 不重绘 NSViewRepresentable 包装的文本字段

ZStack 中的 ProgressView 与 View 的行为不同

无法分配给属性:absoluteString是一个只能获取的属性

`@available` 属性在 macOS 版本上被错误地限制

如何将使用\u{ea12}创建的 Swift 字符串转换回其十六进制值/字符串ea12?

为什么我可以转换为 NSManagedObject 但不能转换为我的实体类型?

为 UIImagePicker 设置委托返回错误

swift中的匿名类

UITableView 布局在 push segue 和 return 上搞砸了. (iOS 8、Xcode beta 5、Swift)