Skip to main content

IO Lab 2



Last week we looked at how to manipulate files using a bunch of classes in Java.nio.file.  This week we will learn how to read and write text files using classes in Java.nio.file package.

  1. Create a directory called “files” in the root folder of the project.
  2. Create a text file called “source.txt” in the files folder.
  3. Create two Path object to hold the source path (“files/source.txt”) and the target path (“files/target.txt”)
  4. Create a Charset object as shown below:
Charset charset = Charset.forName(“US-ASCII”);
  1. Within a try-with-resources block, create a BufferedReader object using the newBufferedReader method of the Files class passing source path and charset as parameters.
  2. In the try-with-resources block that you created before, add a BufferedWriter object using  Files.newBufferedWriter method passing target path and charset as parameter.
  3. Read using the BufferedReader’s readLine method and write to target path using BufferedWriter’s  append method.
  4. Create two new directories in files directory called “backup” and “work”.
  5. Copy the “source.txt” and “target.txt”  to backup folder as “sourceBk.txt” and “targetBk.txt”
  6. Then, move the “source.txt” and “target.txt” to “files/work” folder.
  7. Create a path for the “files” directory that you created in root directory of the project.
  8. Create a class called FileLister that extends SimpleFileVisitor class. Change the generic data type to Path.
  9. Override all the methods in the SimpleFileVisitor class to create the following output to the console when you call Files.walkFileTree() passing directory path and an instance of FileLister.

            files      <dir>
                        backup <dir>
                                    sourceBk.txt
                                    targetBk.txt
                        work    <dir>
                                    source.txt
                                    Target.txt

  1. Create a class called FileSearcher that extends SimpleFileVisitor class. Change the generic data type to Path.
  2. Create a variable called matcher of type PathMatcher
  3. Create a constructor for FileSearcher class that accepts a string parameter.
   public FileSearcher(String pattern) {
        matcher = FileSystems.getDefault().getPathMatcher("glob:" + pattern);
   }
  1. Override visitFile method of the SimpleFileVisitor. Use matcher.matches() to check if the file being visited matches the pattern. If there is a match then add the path to an ArrayList.
  2. Add a getter method for the arrayList called getMatchFound();
  3. In the main method create an instance of  FileSearcher, pass a pattern (for example: “*.txt”) through the constructor. Walk the file tree.
  4. List the matches found to the console.

            files      <dir>
                        backup <dir>
                                    sourceBk.txt
                                    targetBk.txt
                        work    <dir>
                                    source.txt
                                    target.txt

Following matches were found:
files\backup\sourceBk.txt
files\backup\targetBk.txt
files\work\source.txt
files\work\target.txt


  1. Submit a screenshot of the entire source code and the output.







Comments

Popular posts from this blog

CUMIPMT and CUMPRINC function

CUMIPMT Cumulative interest payment function allows you to calculate the interest paid for a loan or from an investment from period A to period B. When getting a loan, CUMIPMT function can be used to calculate the total amount of interest paid in the first five months or from period 12 to period 20. A period can be a month, a week or two week. Loan Amount : 350,000.00 APR: 4.5% Down payment: 0.00 Years: 25 Payment per year: 12 From the above data, we can calculate the following: No of Period: 25 × 12 = 300 Periodic Rate: 4.5/12 = 0.375% Here is how you will substitute these values into the function. = CUMIPMT (periodic rate, No of period, vehicle price, start period, end period,  ) = CUMIPMT (0.375, 300, 350000, 1, 5, 0) In an excel worksheet, we use cell address instead of actual values as shown below: Here is the formula view of the worksheet: CUMPRINC Another related function is CUMPRINC. CUMPRINC function is used to calculate cumul

Excel PMT Function

PMT function is very useful for calculating monthly payment required to payback a loan or mortgage at a fixed rate. This function require a minimum of three inputs, periodic rate, number of periods, present value or the loan amount. Here is a simple example. Home Loan: 350,000.00 Interest rate: 4.5% Number of years to repay the loan: 25 Note: To calculate monthly payment, we need to find the monthly rate and number of months as shown above. Then it is simply a matter of substituting the values into the payment function, as shown in the formula view below.

BCG's Brand Advocacy Index

The Boston Consulting Group's (BCG) Brand Advocacy Index (BAI) is a metric developed to help companies measure the degree of customer advocacy for their brands. BAI focuses on the likelihood of customers to recommend a brand to others, which is a powerful indicator of brand strength and customer loyalty. Unlike other customer satisfaction or loyalty metrics, BAI emphasizes the importance of customer referrals and word-of-mouth marketing. BAI is calculated based on a survey where customers are asked about their willingness to recommend a brand to their friends, family, or colleagues. The responses are then used to compute a score, which ranges from -100 to 100. A higher BAI score indicates that a brand has more advocates who are likely to recommend the brand to others, while a lower score suggests that the brand has fewer advocates or even a higher number of detractors. BCG's research has shown that companies with higher BAI scores tend to experience higher growth rates and bett