zoukankan      html  css  js  c++  java
  • IOS笔记-Foundation之NSString、NSArray

    下面我通过一道编程题:计算文件的代码行数,总结一下NSString、NSArray的使用方法。

    #import <Foundation/Foundation.h>

    /*

     path : 文件的全路径(可能是文件夹、也可能是文件)

     返回值 int:代码行数

     */

    NSUIntegercodeLineCount(NSString *path)

    {

        // 1.获得文件管理者

        NSFileManager *mgr = [NSFileManagerdefaultManager];

       

        // 2.标记是否为文件夹

        BOOL dir = NO; // 标记是否为文件夹

        // 标记这个路径是否存在

        BOOL exist = [mgrfileExistsAtPath:path isDirectory:&dir];

       

        // 3.如果不存在,直接返回0

        if(!exist)

        {

            NSLog(@"文件的路径不存在!");

            return 0;

        }

        // 代码能来到着,说明路径存在

        if (dir)

        { // 文件夹

            // 获得当前文件夹path下面的所有内容(文件夹、文件)

            NSArray *array = [mgrcontentsOfDirectoryAtPath:path error:nil];

            // 定义一个变量保存path中所有文件的总行数

            int count = 0;

            // 遍历数组中的所有子文件(夹)名

            for (NSString *filenamein array)

            {

                // 获得子文件(夹)的全路径

                NSString *fullPath = [NSStringstringWithFormat:@"%@/%@", path, filename];

                // 累加每个子路径的总行数

                count += codeLineCount(fullPath);

            }

            return count;

        }

        else

        { // 文件

            // 判断文件的拓展名(忽略大小写)

            NSString *extension = [[pathpathExtension] lowercaseString];

            if (![extensionisEqualToString:@"h"]

                && ![extensionisEqualToString:@"m"]

                && ![extensionisEqualToString:@"c"])

            {

                // 文件拓展名不是h,而且也不是m,而且也不是c

                return 0;

            }

            // 加载文件内容

            NSString *content = [NSStringstringWithContentsOfFile:path encoding:NSUTF8StringEncoding error:nil];

            // 将文件内容切割为每一行

            NSArray *array = [contentcomponentsSeparatedByString:@" "];

            // 删掉文件路径前面的/Users/apple/Desktop/iOS练习

            NSRange range = [path rangeOfString:@"/Users/apple/Desktop/iOS练习"];

            NSString *str = [path stringByReplacingCharactersInRange:rangewithString:@""];

            // 打印文件路径和行数

            NSLog(@"%@ - %ld", str, array.count);

            return array.count;

        }

    }

    int main()

    {

        NSUInteger count = codeLineCount(@"/Users/apple/Desktop/iOS习");

        NSLog(@"%ld", count);

        return 0;

    }

    void test()

    {

        NSString *str = @"jack rose jim jake";

        [str writeToFile:@"/Users/apple/Desktop/abc.txt" atomically:YESencoding:NSUTF8StringEncoding error:nil];

        NSArray *array = [str componentsSeparatedByString:@" "];

        for (NSString *line in array)

        {

           NSLog(@"%@", line);

        }

        //int count =codeLineCount(@"/Users/apple/Desktop/iOS练习/代码/Foundation/main.m");

        //NSLog(@"count=%d", count);

    }

  • 相关阅读:
    PAT甲题题解1099. Build A Binary Search Tree (30)-二叉树遍历
    PAT甲题题解1098. Insertion or Heap Sort (25)-(插入排序和堆排序)
    PAT甲级题解-1097. Deduplication on a Linked List (25)-链表的删除操作
    字典树trie的学习与练习题
    POJ 1273 Drainage Ditches(网络流dinic算法模板)
    单元最短路径算法模板汇总(Dijkstra, BF,SPFA),附链式前向星模板
    Hungary(匈牙利算法)——二分图最大匹配
    LCIS 最长公共上升子序列
    POJ 1151 Atlantis(经典的线段树扫描线,求矩阵面积并)
    Codeforces 494D Upgrading Array
  • 原文地址:https://www.cnblogs.com/houzhitong/p/4511733.html
Copyright © 2011-2022 走看看