我花了很多时间试图解决这个问题,但我没有快乐。
我在appDelegate中创建了一个数组(levelArrayName),该数组由sqlite数据库填充:
class AppDelegate: UIResponder, UIApplicationDelegate {
var window: UIWindow?
var database:COpaquePointer = nil
var levelArray: [[Int]] = []
var levelArrayName: [[String]] = []
func checkdatabase(){
//check is database exist at path.....
var dirPaths:NSString
dirPaths = NSSearchPathForDirectoriesInDomains(.DocumentDirectory, .UserDomainMask, true)[0] as! NSString;
let databasePath = dirPaths.stringByAppendingString("/rugby.sqlite")
let dbpath = databasePath.cStringUsingEncoding(NSUTF8StringEncoding)
let filemanager = NSFileManager.defaultManager()
if (!filemanager.fileExistsAtPath(databasePath))
{
let fileForCopy = NSBundle.mainBundle().pathForResource("rugby",ofType:"sqlite")
filemanager.copyItemAtPath(fileForCopy!, toPath:databasePath, error: nil)
}
let error = sqlite3_open(dbpath!, &database)
if error != SQLITE_OK
{
println("error while opening");
sqlite3_close(database);
}
}
func getLevels() {
var selectQuery="SELECT * FROM level"
var stmt:COpaquePointer = nil
var result = sqlite3_prepare_v2(database, selectQuery, -1, &stmt, nil);
if result != SQLITE_OK
{
println("failed \(sqlite3_errmsg(database))")
println("failed \(sqlite3_errcode(database))")
}
else
{
result = sqlite3_step(stmt)
while result == SQLITE_ROW {
var levelID = Int(sqlite3_column_int(stmt, 0))
var attackID = Int(sqlite3_column_int(stmt, 2))
var defenceID = Int(sqlite3_column_int(stmt, 2))
var runs = Int(sqlite3_column_int(stmt, 3))
var tries = Int(sqlite3_column_int(stmt, 4))
var name_buf = sqlite3_column_text(stmt, 5)
var name = String.fromCString(UnsafePointer<CChar>(name_buf))
result = sqlite3_step(stmt)
self.levelArray += [[levelID, attackID, defenceID, runs, tries]]
self.levelArrayName += [["\(name)"]]
}
}
}
然后我在我的一个tableviewcontrollers中使用这个数组来设置单元格标签:
import Foundation
import UIKit
let appDelegate = UIApplication.sharedApplication().delegate as! AppDelegate
class LevelsViewController: UITableViewController, UITableViewDelegate, UITableViewDataSource {
var levelArrayName = appDelegate.levelArrayName
override func viewDidLoad() {
super.viewDidLoad()
self.tableView.registerClass(UITableViewCell.self, forCellReuseIdentifier: "cell")
}
override func numberOfSectionsInTableView(tableView: UITableView) -> Int {
return 1
}
override func tableView(tableView: UITableView, numberOfRowsInSection section: Int) -> Int {
return appDelegate.levelArray.count
}
override func tableView(tableView: UITableView, cellForRowAtIndexPath indexPath: NSIndexPath) -> UITableViewCell {
let cell = tableView.dequeueReusableCellWithIdentifier("LevelCell", forIndexPath: indexPath) as! UITableViewCell
cell.textLabel?.text = levelArrayName[indexPath.row][0]
return cell
//return UITableViewCell()
}
但是,单元格标签在数组中的字符串之前显示“Optional:”。
我已经尝试展开appDelegate.levelArrayName,但我似乎无法让它工作。
我确信我错过了一些简单的事情,但我希望能指出正确的方向。
由于
答案 0 :(得分:5)
您需要在数组
中的索引处展开元素if let text = levelArrayName[indexPath.row][0] {
cell.textLabel?.text = text
}
答案 1 :(得分:2)
对于其他与我有同样问题的人,我设法找到答案,大大帮助了这个帖子:Cannot invoke 'append' with an argument list of type '(String?!)'
在AppDelegate中,我更改了我的代码:
self.levelArrayName += [["\(name)"]]
要
if let nameArray = name as String! {self.levelArrayName.append(name!)}
然后不需要打开tableviewcontroller,所以这段代码有效:
cell.textLabel?.text = levelArrayName[indexPath.row]
这似乎是一个简单的答案,但我希望这有助于其他人