Read a userid file and search for userid.json in directory and then search json file
3 ビュー (過去 30 日間)
古いコメントを表示
I know what I need to do, just having a hard to getting it going.
I have this userid.txt file that contains the only user files that I want to consider. If the userid say, 1821407, matches a json file within the directory, for example 1821407.json (all json files have this format), I want to check in the file for some data. I'm thinking I can do the search within the json file part. How do I use Matlab to perform the userid comparison within the directory?
0 件のコメント
採用された回答
Benjamin Kraus
2024 年 7 月 10 日
I suspect you want to use the dir command to get a list of files in the directory, remove ".json" from the end of the file names, then search that list for your target user IDs.
Something like this perhaps:
userIDs = readmatrix('userids.txt');
jsonFiles = dir('*.json');
jsonFileNames = string({jsonFiles.name});
jsonFileUserIDs = extractBefore({jsonFiles.name},".json");
fileExistsForUserID = ismember(string(userIDs), jsonFileUserIDs);
filesWithUserIDInList = ismember(jsonFileUserIDs, string(userIDs));
jsonFilesFromList = jsonFileNames(filesWithUserIDInList);
for f = 1:numel(jsonFilesFromList)
fileName = jsonFilesFromList(f);
data = readstruct(fileName);
% Do whatever you want with the data here.
end
その他の回答 (1 件)
VINAYAK LUHA
2024 年 7 月 10 日
編集済み: VINAYAK LUHA
2024 年 7 月 12 日
Hi Sunshine,
To find the .JSON files with filenames same as the ones in your "userids.txt" file, you may use the MATLAB "textscan" function as follows -
fileID = fopen('userids.txt', 'r');
userIDs = textscan(fileID, '%s');
fclose(fileID);
userIDs = userIDs{1};
% Find uniqueUserIds since some userIds in your list are repeated eg. -226340
uniqueUserIDs = unique(userIDs);
jsonFiles = dir('*.json');
for i = 1:length(uniqueUserIDs)
userID = uniqueUserIDs{i};
jsonFileName = strcat(userID, '.json');
if ismember(jsonFileName, {jsonFiles.name})
fprintf('File %s found.\n', jsonFileName);
else
fprintf('File %s not found.\n', jsonFileName);
end
end
Further, to search within the .JSON files, you can use the MATLAB "fileread" and "jsondecode" functions, For more details refer to the following documentations -
- textscan - https://www.mathworks.com/help/matlab/ref/textscan.html
- fileread-https://www.mathworks.com/help/matlab/ref/fileread.html
- jsondecode-https://www.mathworks.com/help/matlab/ref/jsondecode.html
Hope this helps.
Regards,
Vinayak
3 件のコメント
VINAYAK LUHA
2024 年 7 月 12 日
Hi Sunshine,
You can replace the "userIDs" array with the "uniqueUserIDs" array within the loop in the code.
I have also updated my code to reflect this change.
参考
カテゴリ
Help Center および File Exchange で JSON Format についてさらに検索
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!